-
Notifications
You must be signed in to change notification settings - Fork 9
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
a20f032
commit 3ead28c
Showing
5 changed files
with
229 additions
and
34 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,134 @@ | ||
# md2zhihu | ||
|
||
将markdown转换成 知乎 兼容的 markdown 格式 | ||
|
||
| | md源文件 | 导入知乎的效果 | | ||
|:-- | :-: | :-: | | ||
|使用前 | ![](assets/md.png) | ![](assets/before.png) | | ||
|转换后 | ![](assets/built.png) | ![](assets/after.png) | | ||
|
||
## Install | ||
|
||
System requirement: MaxOS | ||
|
||
```sh | ||
# For rendering table to html | ||
brew install pandoc imagemagick node | ||
npm install -g @mermaid-js/mermaid-cli | ||
``` | ||
|
||
```sh | ||
pip install md2zhihu | ||
``` | ||
|
||
## Usage | ||
|
||
```sh | ||
md2zhihu your_great_work.md | ||
``` | ||
|
||
这个命令将markdown 转换成 知乎 文章编辑器可直接导入的格式, 存储到 `_md2/your_great_work/your_great_work.md`, 然后将图片等资源上传到**当前目录所在的git**的`_md2zhihu`分支. 转换后的markdown文档不依赖任何本地的图片文件或其他文件. | ||
|
||
- `-d` 指定输出目录, 默认为`./_md2/`; 所有文章都会保存在这个目录中, | ||
名为`<article_name>` 的md转换之后保存在`_md2/zhihu/<article_name>/` 目录中, | ||
包括一个名为`<article_name>.md` 的md文件以及所有使用的图片等在同一个目录下. | ||
|
||
转换后所有输出内容将会push到`-r`指定的git repo中或当前目录下的git的repo中. | ||
|
||
- `-r` 指定用于存储图片等资源的git repo url和上传的分支名; 要求是对这个repo有push权限. | ||
|
||
例如要将图片等上传到`github.com/openacid/foo`项目中的`bar`分支: | ||
``` | ||
md2zhihu great.md -r https://github.com/openacid/foo.git@bar | ||
``` | ||
默认使用当前目录下的git配置, (作者假设用户用git来保存自己的工作:DDD), | ||
如果没有指定分支名, md2zhihu 将建立一个`_md2zhihu_{cwd_tail}_{md5(cwd)[:8]}`的分支来保存所有图片. | ||
## 使用 github-action 远程转换, 适合 Windows 用户 | ||
md2zhihu 不支持windows, 可以通过github-action来实现远程转换: | ||
- 首先将要转换的 markdown 全部放在一个 github repo 中, 完成配置后, 每次 push 之后 github-action 将自动构建, | ||
例如 我自己的博客中的文章都在这个repo中: https://github.com/drmingdrmer/drmingdrmer.github.io | ||
- 在文章 repo 中创建 action 描述文件, 定义一个 github-action, | ||
为每次 push 进行转换: | ||
`.github/workflows/md2zhihu.yml`, 内容为: | ||
```yaml | ||
name: md2zhihu | ||
on: [push] | ||
jobs: | ||
md2zhihu: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v2 | ||
- uses: drmingdrmer/[email protected] | ||
env: | ||
GITHUB_USERNAME: ${{ github.repository_owner }} | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
with: | ||
pattern: > | ||
_posts/*.md | ||
_posts/*.markdown | ||
``` | ||
然后将配置文件 commit 到 repo 中: | ||
`git add .github && git commit -m 'action: md2zhihu'` | ||
用以上配置, 在下一次push时, github action 将目录 `_posts/` 中所有的md文件进行转换, | ||
并保存到`_md2zhihu/md` 分支中. | ||
例如我的博客中文章装换后在: | ||
https://github.com/drmingdrmer/drmingdrmer.github.io/tree/_md2zhihu/md/_md2zhihu | ||
- 要使用转换后的文档, 可以直接 merge 这个`_md2zhihu/md`分支 | ||
或直接从github repo 中访问, 例如: | ||
https://github.com/drmingdrmer/drmingdrmer.github.io/blob/_md2zhihu/md/_md2zhihu/dict-cmp.md | ||
## Features | ||
- 公式转换: | ||
例如 ` $$ ||X{\vec {\beta }}-Y||^{2} $$ ` | ||
![](https://www.zhihu.com/equation?tex=%7C%7CX%7B%5Cvec%20%7B%5Cbeta%20%7D%7D-Y%7C%7C%5E%7B2%7D) | ||
转换成可以直接被知乎使用的tex渲染引擎的引用: | ||
``` | ||
<img src="https://www.zhihu.com/equation?tex=||X{\vec {\beta }}-Y||^{2}\\" ...> | ||
``` | ||
- 自动识别block的公式和inline的公式. | ||
- 表格: 将markdown表格转换成html 以便支持知乎直接导入. | ||
- 图片: md2zhihu 将图片上传到github, 并将markdown中的图片引用做替换. | ||
- mermaid: 将mermaid语法渲染成图片, 并上传. 例如: | ||
```mermaid | ||
graph LR | ||
A[Hard edge] -->|Link text| B(Round edge) | ||
B --> C{Decision} | ||
C -->|One| D[Result one] | ||
C -->|Two| E[Result two] | ||
``` | ||
转换成: | ||
![](assets/mermaid.jpg) | ||
- 链接列表: 将 markdown 的 reference-style link 转成链接列表: | ||
| 源文件 | 转换后 | 导入后 | | ||
| :-: | :-: | :-: | | ||
| ![](assets/ref-list/src.png) | ![](assets/ref-list/dst.png) | ![](assets/ref-list/imported.png) | | ||
## Limitation | ||
- 知乎的表格不支持table cell 中的markdown格式, 例如表格中的超链接, 无法渲染, 会被知乎转成纯文本. | ||
- md2zhihu 无法处理jekyll/github page的功能标签例如 `{% octicon mark-github height:24 %}`. 这部分文本目前需要导入后手动删除或修改. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,91 @@ | ||
# markdown一键导入知乎: md2zhihu | ||
|
||
如果你的博客是用markdown编辑的, 例如使用jekyll 或 gihtub page托管, | ||
本文介绍的 md2zhihu 小工具可以帮你实现自动的markdown转换, | ||
将jekyll的markdown转换成知乎兼容的markdown格式. | ||
|
||
| | md | imported | | ||
| :-- | :-: | :-: | | ||
| original | ![](assets/md.png) | ![](assets/before.png) | | ||
| converted | ![](assets/built.png) | ![](assets/after.png) | | ||
|
||
md2zhihu 通过 github action来自动完成, | ||
只需要在保存博客文章的git repo中添加一个action定义: | ||
创建action配置文件 | ||
`.github/workflows/md2zhihu.yml`: | ||
|
||
```yaml | ||
name: md2zhihu | ||
on: [push] | ||
jobs: | ||
md2zhihu: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v2 | ||
- uses: drmingdrmer/[email protected] | ||
env: | ||
GITHUB_USERNAME: ${{ github.repository_owner }} | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
with: | ||
pattern: > | ||
_posts/*.md | ||
_posts/*.markdown | ||
``` | ||
下次提交时, github action将自动把 | ||
`_posts/` 目录下的markdown 转换成可以在知乎一键导入的格式, | ||
转换后的文件存储在另一个分支中: | ||
`_md2zhihu/md`. | ||
|
||
例如我自己的blog [drmingdrmer.github.io](https://drmingdrmer.github.io/) | ||
就是用github page托管, 已经配置好了自动转换脚本: | ||
https://github.com/drmingdrmer/drmingdrmer.github.io/blob/master/.github/workflows/md2zhihu.yml | ||
|
||
最新push后自动转换的文章可以直接在线上看到: | ||
https://github.com/drmingdrmer/drmingdrmer.github.io/tree/_md2zhihu/md/_md2zhihu | ||
|
||
因为自动转换在github服务器上运行, 要使用转换后的文件, | ||
可以直接 fetch then merge 分支 | ||
`_md2zhihu/md`. | ||
或直接在github上打开这个分支看到内容, 例如可以看到我blog中的一篇文章转换后的效果: | ||
https://github.com/drmingdrmer/drmingdrmer.github.io/blob/_md2zhihu/md/_md2zhihu/dict-cmp.md | ||
|
||
|
||
# Options | ||
|
||
下面这些选项也可以使用`with`来传入, 控制转换的行为: | ||
|
||
- `pattern`: | ||
|
||
file pattern to convert | ||
|
||
**required**: True | ||
**default**: `**/*.md` | ||
|
||
- `output_dir`: | ||
|
||
dir to store converted markdown | ||
|
||
**required**: True | ||
**default**: `_md2zhihu` | ||
|
||
- `md_branch`: | ||
|
||
The branch name to push converted markdown to. A build overrides previous built branch. If you want to persist the built markdowns, merge this branch. | ||
|
||
**required**: True | ||
**default**: `_md2zhihu/md` | ||
|
||
- `asset_branch`: | ||
|
||
The branch name in which assets are stored. | ||
|
||
**required**: True | ||
**default**: `_md2zhihu/asset` | ||
|
||
- `target_platform`: | ||
|
||
The platform that the converted markdown should be compatible toṫCurrently supported platforms are zhihu, wechat, weibo, simple. `simple` converts almost everything to images and removes most text styles. E.g. inline code block is converted to normal text. | ||
|
||
**required**: True | ||
**default**: `zhihu` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,2 @@ | ||
__version__ = "0.4" | ||
__version__ = "0.5" | ||
__name__ = "md2zhihu" |