Download all your kindle books script.
Use --readme
command to generate readme file to memory your kindle journey.
到 Release 页面查看最新版本,获取对应系统的二进制文件下载解压即可。
若打开二进制遇到问题,请参考这个 issue
触发了亚马逊风控见 issue
- python3
- requirements
pip3 install -r requirements.txt
Mac 新手指南
基于我的环境和编程背景,我想补充下,没有 Python 经验的程序员,如何使用该开源库。
环境:macOS Catalina 10.15.7
我的编程背景:Android 开发者,使用 Java 和 Kotlin。「 Python3 学过基础语法,**没用 Python3 写过项目** 」
Kindle:我有一台 paperwhite 2
针对 README.md 的教程,自己如何在 [ 命令行 ] 的环境下,来下载电子书?
- 第一步:clone 仓库到下载目录(
~/Downloads
) ;再安装依赖cd ~/Downloads/Kindle_download_helper ; pip3 install -r requirements.txt --user
- 第二步:打开 国内(amazon.cn)电子书所有内容(需要登录自己账户)的页面,按 F12
- 获取 cookie :Network -> Fetch/XHR -> Refresh(Cmd + R) -> 点击任意一个 ajax -> Headers -> Request Headers -> Cookie -> 右键复制它 -> 在 Kindle_download_helper 目录中,新建 cookie_file.txt 来保存 cookie 。
- 获取 CSRF token : Headers 右边 -> Payload -> csrfToken -> 右键复制它。
- 第三步:下载书籍
python3 kindle.py --cn --cookie-file ./cookie_file.txt your_csrf_Token
可能的疑问:
- 为什么安装依赖要加
--user
,可能是权限的问题,于是我按照命令行输出的提示,添加的,就安装依赖成功了; - 你应该始终,在 Kindle_download_helper 目录下,执行命令(
python3 kindle.py ***
)。 - cookie 保存在 Kindle_download_helper/cookie_file.txt 中,方便命令行输入 和 cookie的更新,但如果你要 PR,务必删除 ./cookie_file.txt,以免泄露个人账户信息。
----------------------------- 分割线 -----------------------------
受#41)自动化的启发,如果你有 Shell 脚本的知识,也可以自行写个如下半自动化参考脚本;但前提,依然是你得准备好 cookie 和 csrf_token 。
#!/bin/bash
cd ~/Downloads
git clone https://github.com/yihong0618/Kindle_download_helper.git
cd ~/Downloads/Kindle_download_helper
pip3 install -r requirements.txt --user
# save cookie in ./cookie_file.txt
python3 kindle.py --cn --cookie-file ./cookie_file.txt your_csrf_Token
若默认情况下提示 cookie 无效,你也可以手动输入 cookie 。方法是在上述全部书籍列表页面,按 F12 或右键点击——检查,进入网络面板(Network),找到任意一个 ajax
请求,复制请求头里的 Cookie 即可。同时也能在 Payload 里找到 csrfToken。
然后,执行 python3 kindle.py --cookie ${cookie}
。
你也可以把 cookie 保存为文本文件,执行 python3 kindle.py --cookie-file ${cookie_file}
下载书籍。
或执行过程中提示获取 CSRF token 失败,你可以手动输入 CSRF Token。CSRF Token 可以在页面源码中找到。方法是在浏览器书籍列表页面右键点击,选择查看网页源码,再利用文本匹配工具 (Ctrl + F) 查找 csrfToken
,将等号右边引号中的值复制出来,加到命令行参数中:
# CSRF Token
python3 kindle.py ${csrfToken}
# Both cookie and CSRF Token
python3 kindle.py --cookie ${cookie} ${csrfToken}
如果你的运行环境是本机,项目可以使用 browser-cookie3 库自动从浏览器中获取 cookie。
- 登陆 amazon.cn
- 访问 https://www.amazon.cn/hz/mycd/myx#/home/content/booksAll/dateDsc/
- 右键查看源码,搜索
csrfToken
复制后面的 value - 执行
python3 kindle.py --cn
- 如果下载推送文件
python3 kindle.py --cn --pdoc
- login amazon.com
- visit https://www.amazon.com/hz/mycd/myx#/home/content/booksAll/dateDsc/
- right click this page source then find
csrfToken
value copy - run:
python3 kindle.py
- if is doc file
python3 kindle.py --pdoc
- login amazon.com
- visit https://www.amazon.de/hz/mycd/myx#/home/content/booksAll/dateDsc/
- right click this page source then find
csrfToken
value copy - run:
python3 kindle.py --de
- if is doc file
python3 kindle.py --de --pdoc
- amazon.co.jp にログインする。
- ホームページ https://www.amazon.jp/hz/mycd/myx#/home/content/booksAll/dateDsc/)にアクセスする。
- ソースコード上で右クリックし、
csrfToken
を検索して、それ以降の値をコピーします。 python3 kindle.py --jp
を実行する。- プッシュファイルをダウンロードする場合
python3 kindle.py --jp --pdoc
- cookie 和 csrf token 会过期,重新刷新下 amazon 的页面就行
- 程序会自动在命令执行的目录下创建
DOWNLOADS
目录,书会下载在DOWNLOADS
里 - 如果你用 DeDRM_tools 解密 key 存在 key.txt 里
- 或者直接拖进 Calibre 里 please google it.
- 如果过程中失败了可以使用 e.g.
--resume-from ${num}
- 如果出现名字太长的报错可以增加:
--cut-length 80
来截断文件名 - 支持推送文件下载
--pdoc
- 如果有很多同名 pdoc 或 book 可以使用
--resolve_duplicate_names
解决同名冲突 - error log 记录在 .error_books.log 中
- 支持生成最近读完书的 README
--readme
生成的文件在my_kindle_stats.md
中
- The cookie and csrf token will expire, just refresh the amazon page again.
- The program will automatically create
DOWNLOADS
directory under the command execution directory, the book will be downloaded inDOWNLOADS
directory. - If you use DeDRM_tools to decrypt the key, it will be stored in key.txt
- or just drag it into Calibre. Please google it.
- If the process fails you can use e.g.
--resume-from ${num}
- If the name is too long, you can add:
-cut-length 80
to truncate the file name - Support push file download
--pdoc
- If there are many pdocs or books with the same name, you can use
--resolve_duplicate_names
to resolve conflicts with the same name. - error log is logged in .error_books.log
- Support for generating READMEs of recently finished books
--readme
generated files are inmy_kindle_stats.md
- Any issues PR welcome
black kindle.py
- 谢谢就够了