Scrapy抓取简书热门生成电子书发送到Kindle

简书是个学习的好网站, 我大多只关注首页上的人们文章, 但是最近因为忙错过了很多首页上的文章,所以有了想法把每天的热门top生成mobi推送到kindle。这样在地铁上也能快速翻完.

环境准备:

  • 一台主机(需要联网)
  • Gitbook
  • calibre(Gitbook 依赖calibre的ebook-convert)
  • Python2.7.9(calibre 需要python2.7.9)
  • 项目地址: jianshuHot

关于calibre安装

sudo -v && wget -nv -O- https://raw.githubusercontent.com/kovidgoyal/calibre/master/setup/linux-installer.py | sudo python -c "import sys; main=lambda:sys.stderr.write('Download failed\n'); exec(sys.stdin.read()); main()"
<\>Bash

官网文档提供的安装脚本看似简单, 执行之后也可以安装使用了, 但是gitbook调用ebook-convert时候会报错, 这个地方报错应该是QT的错误(至少我遇到的是, 具体错误信息忘记截图了)如果遇到此错误直接安装QT pyQT即可. calibre 安装页面有依赖表

Gitbook 安装

需要安装nodejsnpm然后执行npm install -g gitbook-cli

安装jianshuHot

需要强调的是此部分需要解决大量的依赖,

scrapy所依赖的python包很多, 而且这些依赖的python大多需要一些系统库, 必要的时候需要apt-getyum安装一下, 如python-devel libffi-devel libxml-devel等....

peewee (数据库ORM)要mysql-devel, 以上举例都是已知的, 这是在我部署之后写的, 部署的过程没有详细记录, 现在只能靠回忆来写本章节.

$ git clone https://github.com/jackeyGao/jianshuHot
$ cd jianshuHot
$ pip install -r requirements.txt
<\>Bash

初始化程序

$ sh init.sh
<\>Bash

邮件配置

这里发送邮件使用的sendEmail, 下载地址 . 解压后把解压的sendEmail重命名到/usr/local/bin/sendEmail理论上都能安装成功, 这个是免编译的, 只需要机器上安装了perl

然后修改start.sh 邮箱配置, 写成你自己163邮箱, 也可以用其他品牌邮箱, 如果你用其他品牌别忘了改下smtp.163.com, 改成相应的smtp服务器即可.

注意: 无论你用哪个邮箱都必须把此邮箱账号加入亚马逊已认可的发件人电子邮箱列表, 确保发送的文档能到达亚马逊Cloud

$ vim start.sh
....
YOURKINDLE_MAIL_ADDRESS="[email protected]"
YOUR_SEND_MAIL_USERNAME="[email protected]"
YOUR_SEND_MAIL_SECRET = 'xxxxxxxxxxxx'
MOBI_BOOK_PATH='./output/book.mobi'
...
<\>Bash

开始抓取生成

$ sh start.sh
<\>Bash

执行后会自动抓取页面生成markdown, 下载每个文章的图片, 然后gitbook通过markdown生成此次文档列表的book.mobi (output/book.mobi), 在start.sh 最后面有个备份的操作, 会把此次的mobi备份到output/books. 然后发送到指定的kindle地址邮箱.