/Kindle_download_helper

Download all your kindle books script.

Primary LanguagePythonMIT LicenseMIT

Kindle_download_helper

Download all your kindle books script.

image

Use --readme command to generate readme file to memory your kindle journey.

image

下载二进制文件

Release 页面查看最新版本,获取对应系统的二进制文件下载解压即可。

若打开二进制遇到问题,请参考这个 issue

无法下载问题

触发了亚马逊风控见 issue

Cli

  1. python3
  2. requirements
pip3 install -r requirements.txt

推荐手动输入 cookie

手动输入 cookie

若默认情况下提示 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。CSRF Token 可以在页面源码中找到。方法是在浏览器书籍列表页面右键点击,选择查看网页源码,再利用文本匹配工具 (Ctrl + F) 查找 csrfToken,将等号右边引号中的值复制出来,加到命令行参数中:

# CSRF Token
python3 kindle.py ${csrfToken}
# Both cookie and CSRF Token
python3 kindle.py --cookie ${cookie} ${csrfToken}

自动获取 cookie

如果你的运行环境是本机,项目可以使用 browser-cookie3 库自动从浏览器中获取 cookie。

使用 amazon.cn

  1. 登陆 amazon.cn
  2. 访问 https://www.amazon.cn/hz/mycd/myx#/home/content/booksAll/dateDsc/
  3. 右键查看源码,搜索 csrfToken 复制后面的 value
  4. 执行 python3 kindle.py --cn
  5. 如果下载推送文件 python3 kindle.py --cn --pdoc

how to amazon.com

  1. login amazon.com
  2. visit https://www.amazon.com/hz/mycd/myx#/home/content/booksAll/dateDsc/
  3. right click this page source then find csrfToken value copy
  4. run: python3 kindle.py
  5. if is doc file python3 kindle.py --pdoc

amazon.jp を使用する

  1. amazon.co.jp にログインする。
  2. ホームページ https://www.amazon.jp/hz/mycd/myx#/home/content/booksAll/dateDsc/)にアクセスする。
  3. ソースコード上で右クリックし、csrfTokenを検索して、それ以降の値をコピーします。
  4. python3 kindle.py --jp を実行する。
  5. プッシュファイルをダウンロードする場合 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

Note

  • 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 in DOWNLOADS 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 in my_kindle_stats.md

image

贡献

  1. Any issues PR welcome
  2. black kindle.py

感谢

赞赏

  • 谢谢就够了

Enjoy