This repository is a collection of Duolingo courses' vocabs.
Currently, the only course is Spanish (learned from English) in the "english-spanish" folder.
The list of words for a course can be downloaded in JSON and CSV format.
The main purpose of this project is to provide a means of getting the vocab in a format that is easy to import into a memorization tool. Tinycards does not seem to be maintained that well anymore (sadface).
Originially, I wrote this program to parse the words in the Spanish course from an awesome post in a Duolingo discussion (which is gone now because Duolingo sunset the forums 🥲). Thank you so much FieryCat for your inspiration from that post though!
However, now the program parses words from the website duome which has a very comprehensive list of the words for each course. Switched to this approach based on the detailed blog post by Melle Dijkstra.
To use the provided code:
Run git clone git@github.com:jmbeach/duolingo-vocab-lists.git
Run yarn install
.
Run yarn build
.
Login to Duolingo.com. Open the network tab and look for a request that has the word acquisition in it. Open the Response tab and copy all of the text. Save the text to a file locally (like english-spanish/raw-course-data.json
).
Note: This file may have sensitive data in it. Be sure to delete anything sensitive before committing it to your repo.
Go to https://duome.eu/<your-user-name>/progress
. The skills tab contains an in-order list of all of the skills in your language. In the chrome developer console, run document.querySelectorAll('.click.skill')
to expand every item on the page.
Once you've ran the querySelectorAll command, save the page to an HTML file. NOTE: you may have to clean the html file to ensure there is only one root note. For example: only Body as root.
Run deno run src/index.ts download -f <path-to-vocab-html-file> -s <path-to-course-data-json> [-a <google-api-key>]
to download the translations to a JSON file.
The translator defaults to finding transaltions of words on Duolingo.com. However, if it can't find one, it uses Google Translate. To use google translate you'll have to get an API key and then put your API key into a .env file like this:
GOOGLE_TRANSLATE_API_KEY=<my-api-key>
NOTE: Make sure to change your desired language pair inside TranslationDownloader
(it's es
, en
by default).
Finally, run deno run src/index.ts create -f <path-to-json-file>
to turn the translations into CSV's.
If the new CSV's aren't in this repository yet, please feel free to create a pull request to add them. Currently, I've only processed Spanish (for English speakers), but would love to get other languages in here.
It might be preferable for some people to have all of the CSV files for each section combined into one file. To generate these, run deno run src/index.ts combine -p <path to language directory>
.