youdaonote-pull

youdaonote-pull

有道云笔记本地导出工具 支持Markdown转换

youdaonote-pull是一个开源工具,用于将有道云笔记导出到本地。它支持原格式下载、Markdown转换和图片本地化。该工具在本地运行,保护数据安全。提供可执行程序,方便非技术用户使用。适合需要备份或迁移有道云笔记的用户。

有道云笔记导出备份PythonMarkdownGithub开源项目

youdaonote-pull

现在有道云笔记不能导出笔记,迁移笔记很麻烦。此脚本可将所有笔记下载到本地。脚本完全本地运行,你不用担心数据安全。

功能

  • 可将所有笔记(文件)按原格式下载到本地
  • 由于「笔记」类型文件下载后默认为 Xml 或者是 Json 格式,不是正常笔记内容,默认将其转换为 Markdown 格式
  • 由于有道云笔记图床图片不能在有道云笔记外显示,默认将其下载到本地,或指定上传到 SM.MS

非技术人员使用

如果你是非技术人员,也提供可直接本地运行程序,不需要安装 Git、Python 和下载代码。具体使用教程请看更简单的「有道云笔记」导出与备份

使用步骤

一、导出前的准备工作

1、安装 Git、克隆项目

git --version
  • 打开命令行软件,如 Terminal (macOS)、PowerShell (Windows),克隆项目,里面包含脚本
pwd git clone https://github.com/DeppWang/youdaonote-pull.git cd youdaonote-pull

2、安装 Python3、安装依赖模块(包)

python3 --version # macOS/Linux python --version # Windows
  • 安装依赖包
# macOS sudo easy_install pip3 # 安装 Python3 包安装器 python3 -m venv venv # 使用虚拟环境 . venv/bin/activate # 激活虚拟环境 sudo pip3 install -r requirements.txt
# Windows python -m venv venv # 使用虚拟环境 . venv/bin/activate # 激活虚拟环境 pip install -r requirements.txt # 有问题可参考 https://www.liaoxuefeng.com/wiki/1016959663602400/1017493741106496

3、设置登录 Cookies 文件 cookies.json

{ "cookies": [ [ "YNOTE_CSTK", "**", ".note.youdao.com", "/" ], [ "YNOTE_LOGIN", "**", ".note.youdao.com", "/" ], [ "YNOTE_SESS", "**", ".note.youdao.com", "/" ] ] }

由于有道云笔记登录升级,加了图形验证码。目前脚本不能使用账号密码登录,只能使用 Cookies 登录。

你可以通过安装插件「Cookie-copy」快速复制 Cookie。

或者直接在浏览器开发者工具中获取 Cookies

  1. 在浏览器如 Chrome 中使用账号密码或者其他方式登录有道云笔记
  2. 打开开发者工具 (F12),Network 下找「主」请求(一般是第一个),再找 Cookie
  3. 复制对应数据替换 **

image.png

示例:

{ "cookies": [ [ "YNOTE_CSTK", "rR_Pejz0", ".note.youdao.com", "/" ], [ "YNOTE_LOGIN", "3||1649054441155", ".note.youdao.com", "/" ], [ "YNOTE_SESS", "v2|BdllbnwfaWl5RMUWOfqZ0gShf***6LqFRqB0MYfh4JLR", ".note.youdao.com", "/" ] ] }
  • 提示:脚本完全本地运行,不用担心你的 Cookies 泄露

4、设置脚本参数配置文件 config.json

建议使用 Sublime 等第三方编辑器编辑 config.json,避免编码格式错误

{ "local_dir": "", "ydnote_dir": "", "smms_secret_token": "", "is_relative_path": true }
  • local_dir:选填,本地存放导出文件的文件夹(绝对路径),不填则默认为当前文件夹
  • ydnote_dir:选填,有道云笔记指定导出文件夹名,不填则导出所有文件
  • smms_secret_token:选填,SM.MSSecret Token(注册后 -> Dashboard -> API Token),用于上传笔记中有道云图床图片到 SM.MS 图床,不填则只下载到本地(youdaonote-images 文件夹),Markdown 中使用本地链接
  • is_relative_path:选填,在 MD 文件中图片/附件是否采用相对路径展示,不填或 false 为绝对路径,true 为相对路径

示例:

  • macOS
{ "local_dir": "/Users/deppwang/Documents/youdaonote-pull/test", "ydnote_dir": "", "smms_secret_token": "SGSLk9yWdTe4RenXYqEPWkqVrx0Yexample" }
  • Windows
{ "local_dir": "D:/Documents/youdaonote-pull/test", "ydnote_dir": "", "smms_secret_token": "SGSLk9yWdTe4RenXYqEPWkqVrx0Yexample" }

二、运行导出脚本

python3 pull.py # macOS/Linux python pull.py # Windows

效果: image-20240430154201191

三、多次导出

多次导出时,同样使用以下命令:

python3 pull.py # macOS/Linux python pull.py # Windows

根据有道云笔记文件最后修改时间是否大于本地文件最后修改时间来判断是否需要更新。再次导出时,只会导出有道云笔记上次导出后新增、修改或未导出的笔记,不会覆盖本地已经修改的文件。但有道云笔记和本地不要同时修改同一个文件,这样可能会导致本地修改丢失

更新时,会重新下载文件并覆盖原文件,图片也会重新下载。

注意事项

  1. 如果你自己修改脚本,注意不要将 cookies.json 文件 push 到 GitHub
  2. 如果你不是开发者,可能对上面的命令行操作有所陌生,建议按步骤慢慢操作一遍
  3. 请确认代码是否为最新,有问题请先看 issue 是否存在,不存在再提 issue
    git pull origin master # 更新代码

原理

正常用户浏览器操作时,浏览器(前端)调用服务器(后端)接口,接口返回文件内容由前端渲染显示。原理是找到有道云笔记的接口,模拟操作接口,将前端显示改为存放到本地。Xml 转换为 Markdown,借助了 xml.etree.ElementTreeI

感谢(参考)

出发点

原来一直是有道云笔记的忠实用户,后面接触到了「所见即所得」的 Typora,有点用不惯有道云笔记了,想着有什么法子能电脑本地文件和有道云笔记同步,这样电脑使用 Typora,手机使用有道云笔记。发现有道云笔记有 Open API ,打算利用提供的 API,写两个脚本,一个 pull 所有文件到本地,一个 push 本地文件到云笔记。但 API 太难用了,N 多年没更新了,问客服也没更新的意思,开发到最后发现竟然没有 Markdown 文件的接口,醉了。遂放弃。

发现有道云笔记最新的 Mac 客户端和网页端去除了导出所有笔记的功能!这是什么逻辑,怕用户跑了么。所以在原来 pull 脚本的基础上修改得到此脚本。

现在我使用 Obsidian + iCloud + 1Writer 实现自动同步笔记和手机查看编辑的功能,很香。使用教程

贡献

欢迎贡献代码,但有几个注意事项:

  1. commit 请使用英文;一次 commit 只改一个点;一个 commit 一个 PR
  2. 代码注释需要有中英文空格
  3. 请确保通过测试用例:在 macOS 和 Windows 环境中直接执行 python3 test/test.py 没有问题

编辑推荐精选

TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
商汤小浣熊

商汤小浣熊

最强AI数据分析助手

小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。

imini AI

imini AI

像人一样思考的AI智能体

imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。

Keevx

Keevx

AI数字人视频创作平台

Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。

即梦AI

即梦AI

一站式AI创作平台

提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作

扣子-AI办公

扣子-AI办公

AI办公助手,复杂任务高效处理

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

蛙蛙写作

蛙蛙写作

AI小说写作助手,一站式润色、改写、扩写

蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。

AI辅助写作AI工具蛙蛙写作AI写作工具学术助手办公助手营销助手AI助手
问小白

问小白

全能AI智能助手,随时解答生活与工作的多样问题

问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。

热门AI助手AI对话AI工具聊天机器人
Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
下拉加载更多