Skip to main content

A tool for studying Leetcode with Python

Project description

💻 Leetcode Study Tool

Tests Status Style Status Python Versions PyPi contributions welcome

Leetcode Study Tool Diagram

This package lets you get grokking as quickly as possible with Leetcode. It provides a command-line tool for interracting with Leetcode to create either an Excel file or Anki flashcards for study. Currently, this tool supports taking in a list of leetcode question slugs or URLs or popular study sets (including the Blind 75, Grind 75, and Neetcode 150).

🤔 Why?

This package was created as an opinionated alternative to other existing packages (as listed at the bottom of this README).

📥 Installation

$ pip install leetcode-study-tool

💻 Usage

usage: leetcode-study-tool [-h]
                           (--url URL | --file FILE | --preset {blind_75,grind_75,grind_169,neetcode_150,neetcode_all})
                           [--format {anki,excel}] [--csrf CSRF] [--output OUTPUT]
                           [--language LANGUAGE]

Generates problems from LeetCode questions in a desired format.

options:
  -h, --help            show this help message and exit
  --url URL, -u URL     The URL(s) or slug(s) of the LeetCode question(s) to generate
                        problem(s) for. (default: None)
  --file FILE, -f FILE  The file containing the URL(s) or slug(s) of the LeetCode question(s)
                        to generate problem(s) for. (default: None)
  --preset {blind_75,grind_75,grind_169,neetcode_150,neetcode_all}, -p {blind_75,grind_75,grind_169,neetcode_150,neetcode_all}
                        The preset to use to generate problem(s) for. (default: None)
  --format {anki,excel}, -F {anki,excel}
                        The format to save the Leetcode problem(s) in. (default: anki)
  --csrf CSRF, -c CSRF  The CSRF token to use for LeetCode authentication. (default: None)
  --output OUTPUT, -o OUTPUT
                        The output file to write the problem(s) to. (default: output.txt)
  --language LANGUAGE, -l LANGUAGE
                        The language to generate problem(s) for. (default: None)

💡 Example

In the simplest case, if you want to Grok the most commonly asked questions, you should generate from a preset. For example, generating Anki cards from the Grind 75 is as simple as

$ leetcode-study-tool -p grind_75

Perhaps, instead, you'd prefer to import questions that you've already worked on. In a directory with a file named questions.txt, where each line is either a Leetcode problem URL or slug (or a combination of both), we can run the command

$ leetcode-study-tool -f questions.txt 

which will generate the file output.txt. We can then open Anki to import these problems as demonstrated below, ensuring to select semicolon as a field separator.

anki demo

📒 Anki

When generating an Anki output, the resulting "cards" are saved as a .txt file. These cards include three fields:

  1. The front of the study card, containing the question ID, Title, URL, and problem description
  2. The publicly available solutions (and NeetCode solution, if available)
  3. The tags associated with the problem (i.e., if the problem involves a hash map, arrays, etc...)

📊 Excel

When generating an Excel output, the resulting questions are saved in an .xlsx file. Each problem includes the following fields:

  1. ID of the leetcode question
  2. Title of the leetcode question
  3. URL of the leetcode question
  4. Last date that this question was attempted by the user (please note that this is not pulled from your leetcode profile, but left for you to update as you progress in solving leetcode questions)
  5. The tags associated with the problem (i.e., if the problem involves a hash map, arrays, etc...)
  6. Neetcode video link (if it exists)
  7. Solution links for the problem (if they are reachable)
  8. Companies that have asked this question recently in interviews (if they are reachable)

🛣 Roadmap

  • Use TQDM to show card generation progress
  • Add support for exporting to an excel sheet
  • Add support for showing neetcode solutions on the back of the card as a
  • Add support for getting the difficulty of questions
  • Add support for fetching premium questions via authentification
  • Add support for importing cards into Quizlet
  • Add support for fetching questions by topic or tag link
  • Allow for the definition of custom formatters and outputs (including which fields are included or excluded)
  • Reach 90% test coverage

🔎 Other Usefull Stuff

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

leetcode-study-tool-1.2.3.tar.gz (26.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

leetcode_study_tool-1.2.3-py3-none-any.whl (22.4 kB view details)

Uploaded Python 3

File details

Details for the file leetcode-study-tool-1.2.3.tar.gz.

File metadata

  • Download URL: leetcode-study-tool-1.2.3.tar.gz
  • Upload date:
  • Size: 26.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for leetcode-study-tool-1.2.3.tar.gz
Algorithm Hash digest
SHA256 6895226e34b485a3c6c88f4cb3c218852a9173b40c5f24bd63624f0a58332586
MD5 1b6eb4356fff528467f0a08bf2d984cf
BLAKE2b-256 2f8527de6a7040214f67bc13bd401bd87edda6c22f3a375b09357b892948d3d4

See more details on using hashes here.

File details

Details for the file leetcode_study_tool-1.2.3-py3-none-any.whl.

File metadata

File hashes

Hashes for leetcode_study_tool-1.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 5b4e8186d63429b31f01665289982579e05ee7ccaf8f5a3f29eeaced49c7694f
MD5 4a4d531c26abe4f7d49f43639986cb8a
BLAKE2b-256 a2b897a4eb558ad71ceef443254c1ed0b8a1a80940002f8e2033f42c680c8c1b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page