背景: 写博客的时候每当新增 LeetCode 题解时都需要在 https://github.com/MuYunyun/blog/blob/master/LeetCode/README.md 手动更新表格, 非常费劲。因此构思了该插件实现自动化同步更新 leetcode ac 题解为 markdown table 。
crd-leetcode-cli 提供将 leetcode 中已 AC 的题目转化为 markdown 表格的能力。
执行 yarn add crd-leetcode-cli -g
, 国内用户可以执行 cnpm install crd-leetcode-cli -g
leetcode download // 增量拉取 AC 题目(若无登录, 则会先执行登录逻辑) leetcode download -a // 全量拉取 AC 题目 leetcode login // 登录 leetcode logout // 登出
插件提供了自定义渲染 markdown table 的能力。
const transform_markdown_table = (dataArr) => { const beforeDescription = `The markdown table is generated by [crd-leetcode-cli]( https://github.com/MuYunyun/create-react-doc/tree/master/packages/leetcode-cli)`; let result = beforeDescription + '\n' + '| # | Title | Explanation | Difficulty | Type |' + '\n' + '|:---:|:---:|:---:|:---:|:---:|'; for (let i = 0; i < dataArr.length; i++) { result += `\n| ${dataArr[i].questionId} | [${dataArr[i].title }]( https://leetcode.com/problems/${dataArr[i].titleSlug }/) | [Analyze]( https://github.com/MuYunyun/blog/blob/master/LeetCode/${dataArr[i].questionId }.${dataArr[i].title.split(' ').join('_')}.md) | ${dataArr[i].difficulty } | ${dataArr[i].topicTags} |`; } return result; }; module.exports = { transform_markdown_table }
通过自定义 transform_markdown_table 函数, 便可得到如下 markdown table:
![]() | 1 jiangshanmeta 2020-09-30 15:58:21 +08:00 题主 为了完成同样的事情,我只用了一个[node 脚本]( https://github.com/jiangshanmeta/meta/blob/master/scripts/generate.js) |
![]() | 2 muyunyun OP @jiangshanmeta 神奇, 调用 restful 接口不用 cookie 就能访问么。。我这边多了一步登陆操作, 成本其实相差不大, 后续涉及到编辑的接口也能访问了。 |
![]() | 3 muyunyun OP |
![]() | 4 asanelder 2020-09-30 19:22:11 +08:00 挺好,不错,鼓励,给个赞 |
![]() | 5 xrr2016 2020-10-01 07:33:57 +08:00 via iPhone 标记 |