把一篇简书 markdown 博客同步到其他博客平台的 python 脚本

需求

辛辛苦苦写完一篇质量比较高的技术博客,很多开发者朋友都会把它发到简书、掘金、个人博客等数个平台。我也不例外,一般是先在简书写好,因为简书的 markdown 编辑器用起来比较舒服,而且传图片比较方便:只需把要传的图片粘贴到剪切板上,在编辑框里 Command-V 一下,就自动上传图片、并生成相应的 markdown 代码了。

但是往别的平台发的时候有个小问题。第一次,我直接把简书博客全文复制粘贴到掘金的编辑框里,就发出去了;很快就收到掘金编辑的微信:“你的图挂啦!快去看看吧!”原来,简书会自动把博客里的图片重传一次,放在自己的图片服务器 upload-images.jianshu.io 上。而这个服务器对站外访问是有一定限制的,贴到掘金上自然就访问不到了。

于是,每次在简书发完文章,我都要把所有图片再往我自己的七牛空间重新传一份,然后用七牛的图片链接逐一替换简书的图片链接。这个过程很重复,也很无聊,为什么不能用脚本自动化处理一下呢?因此,我写了这个用于同步简书博客的 python 脚本。


使用

环境准备

这个脚本在 python 2.7.1 下运行通过。图床用的是七牛云存储。
七牛的 python sdk 需要安装 requests,没装的朋友可以在 terminal 里运行 sudo easy_install -U requests 来安装。

源码地址

源码放在 Github 上,地址戳这里

用法

  1. 把脚本源码下载到本地
  2. 填写源码中的以下部分:
    # 在此处填写你的七牛 Access Key 和 Secret Key
    accessKey = '...'
    secretKey = '...'
    q = Auth(accessKey, secretKey)
    
    # 七牛上的 bucket 名
    bucketName = '...'
    # 这个 bucket 的外链前缀,就是七牛后台的“外链默认域名”
    imageUrlPrefix = "http://xxxxxx.bkt.clouddn.com/"
    
  3. 把 blog.txt 里的文本替换成自己的博客内容
  4. 在 terminal 中切换到脚本根目录,运行:python blogbot.py,会看到以下输出:

$ python blogbot.py
正在解析文件...
正在下载图片...
下载中:1 / 4
下载中:2 / 4
下载中:3 / 4
下载中:4 / 4
正在上传图片...
上传中:1 / 4
上传中:2 / 4
上传中:3 / 4
上传中:4 / 4
正在写入文件...
完成啦~
```

  1. 新生成的博客就在脚本根目录下的 newBlog.txt 里。拿去用吧:)

源码讲解

为什么选择 python?

其实用任何一种脚本语言都可以。七牛还有 javascript 的 sdk,所以一开始想做成一个网页的。不过因为涉及到需要填写七牛的 Access Key 和 Secret Key,感觉在本地运行更安全一些(而且懒得画网页了……),所以用的 python。

脚本流程

  1. 读文件
  2. 从博客正文中识别图片链接
    这一步用的是正则表达式,简单匹配 markdown 的图片语法,提取出所有的图片链接。
  3. 下载图片
    用 python 的 urllib.urlretrieve 下载图片,自动命名为 image1image2……
  4. 上传图片到七牛
    使用七牛的 python SDK。自动命名为形如 blog20161027_image1 的文件名,前面拼上七牛的外链前缀,即得到七牛上的外链地址。
  5. 替换链接
  6. 写文件

源码很简单,我注释也写得挺详细的,一看源码就明白了。

局限性

主要是为了我自己的需求使用,很多地方考虑得比较简单。比如:

  • 正则表达式只是简单匹配了 markdown 的图片语法,并没有考虑例如“图片语法在代码段里“之类的情况。
  • 图片的命名比较简单粗暴,不能满足一天处理两篇文章的需求(第二篇文章的图片会覆盖第一篇)。如果有这种需求,可以简单修改一下命名那部分的代码。

就是这样一个很简单的小脚本,希望能为大家的生活带来方便~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,242评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,769评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,484评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,133评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,007评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,080评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,496评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,190评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,464评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,549评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,330评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,205评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,567评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,889评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,160评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,475评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,650评论 2 335

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,047评论 25 707
  • 很久以前,当我学习算卦,看命,看相等五术时,本来抱着的目标是想告诉自己能够结合我所学的,以及我所经历的经验来帮助更...
    释道生阅读 478评论 2 3
  • 我,徐云,一个心理教育工作者,二届生命志工,三届生命志工助教。 以往生命中有很多故事的我,曾经孤独、愤怒、悲伤、疏...
    徐云阅读 396评论 0 7