分享一款將 LeetCode 中 AC 的題目轉化爲 MarkDown 表格的插件

背景: 寫博客的時候每當新增 LeetCode 題解時都須要在 LeetCode/README 手動更新表格, 很是費勁。所以構思了 crd-leetcode-cli 插件實現自動化同步更新 leetcode ac 題解爲 markdown table 。react

crd-leetcode-cli

crd-leetcode-cli 提供將 leetcode 中已 AC 的題目轉化爲 markdown 表格的能力。git

Install

執行 yarn add crd-leetcode-cli -g, 國內用戶能夠執行 cnpm install crd-leetcode-cli -ggithub

Usage

leetcode download       // 增量拉取 AC 題目(若無登陸, 則會先執行登陸邏輯)
leetcode download -a    // 全量拉取 AC 題目
leetcode login          // 登陸
leetcode logout         // 登出
接入項目示例

Render Markdown Table Customly

插件提供了自定義渲染 markdown table 的能力。npm

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:json

Technology Details

  • 使用 puppeteer 登陸 leetcode 獲取 cookie 信息。markdown

  • 獲取 cookie 後, 使用 graphql-request 調用 graphql 接口獲取題目詳情信息。
  • 自定義生成 markdown table
相關文章
相關標籤/搜索