Skip to content

Latest commit

 

History

History
 
 

wereader

微信读书助手(爬虫) wereader

本项目基于 @arry-lee 的项目 wereader 修改而来,并借鉴了 @shengqiangzhang 的[一键导出微信读书的书籍和笔记](https://github.com/shengqiangzhang/examples-of-web-crawlers/tree/master/12. 一键导出微信读书的书籍和笔记)中的 GUI 登录方法,感谢原作者、感谢开源。

主要功能

  1. 获取某本书的全部标注(笔记)
  2. 获取某本书指定章节的标注
  3. 获取某本书你的个人想法
  4. 获取某一本书的热门划线
  5. 获取某本书的目录
  6. 获取某本书的详情(书本信息)
  7. 获取某本书你的最新标注
  8. 获取书架上的书籍列表
  9. 自定义标注效果、标题级别
  10. 删除某本书所有标注
  11. 导出书评

针对上面所获取的大多数内容,使用时有两方面的操作选择:一是输出到控制台并复制到剪切板;二是追加到指定文件。

主要代码见 wereader.py

如何运行

# 跳转到当前目录
cd 目录名
# 安装依赖库
pip install -r requirement.txt -i https://pypi.tuna.tsinghua.edu.cn/simple
# 开始运行
python main.py

如果运行出错,尝试先卸载依赖库:

# 跳转到当前目录
cd 目录名
# 先卸载依赖库
pip uninstall -y -r requirement.txt
# 再重新安装依赖库
pip install -r requirement.txt -i https://pypi.tuna.tsinghua.edu.cn/simple
# 开始运行
python main.py

操作简介

输入命令

python main.py

运行程序之后。

程序会提示登录,登录成功后会输出书架并提示输入书本 id(书名前面的那一串数字):

输入 id 后会列出操作指南:

这时候有两类操作可以选择:print 选项的功能是输出内容到控制台并复制到剪切板;push 选项的功能是将内容追加到文件末尾。

比如,现在想要将这本书的想法输出到控制台并复制到剪切板,只需要输入 print 2 再回车:

同样,如果想要将想法追加到文件,输入push 2即可:

其中有关“个人最新标注”的选项,是用来随时输出新标注(而不让内容重复)的功能。

如果你喜欢读一部分做一部分的笔记,那么这个功能对你可能比较有帮助。

push 1print 1 只能够输出书中的所有标注或某一章的标注,这使得你要么全部做好笔记后一次性导出标注,要么每读完一章后做一次笔记。

push 6print 6 则能够让你随时导出最新标注好的内容(初次使用时将只是记录最新内容所在位置,相当于初始化)。这个选项中有两种寻找最新内容的方式,一种效果不佳可以尝试另一种。

标注效果

可以通过编辑源文件来设置标注效果。

打开 wereader.py,找到下面的代码:

level1 = '## '#(微信读书)一级标题
level2 = '### '#二级标题
level3 = '#### '#三级标题
style1 = {'pre': "",   'suf': ""}#(微信读书)红色下划线
style2 = {'pre': "**",   'suf': "**"}#橙色背景色
style3 = {'pre': "",   'suf': ""}#蓝色波浪线
thought_style = {'pre': "```\n",   'suf': "\n```"}#想法前后缀
hotmarks_number = {'pre': "`",   'suf': "`  "}#热门标注标注人数前后缀

三个 level 变量分别代表三级标题,如果你想将改变导出内容的标题级别,可以在这里修改井号个数。

三个 style 变量代表微信读书中的三种标注(见注释),可以在这里设置标注效果,pre 代表前缀,suf 代表后缀。

比如这里的设置表示:不给用红色下划线和蓝色波浪线标注的部分添加前缀和后缀、给橙色背景色标注的部分添加前后缀 ** ,也就是给它加粗。如果你想要将红色下划线标注的部分设置为 Markdown 格式的下划线内容,只需要将 style1 设置为 style1 = {'pre': "<u>", 'suf': "</u>"},也就是给它添加 Markdown 中的下划线标签。

变量 thought_stylehotmarks_number 类似,分别用于设置想法和热门标注人数的前后缀。

补充

  • 项目托管于 GitHub
  • 如果 gif 动画没有播放,可以到这里查看。

License

The MIT License (MIT)