Make ZIM files from freeCodeCamp courses
Project description
freeCodeCamp scraper
This scraper downloads selected freeCodeCamp courses and puts it in a ZIM file, a clean and user friendly format for storing content for offline usage.
Architecture
This project consists of two major components:
zimui
- A Vue.JS application specially crafted to:- be embeded inside the ZIM and serve as main entry point (through compilation for offline usage with Vite)
- present FCC curriculum, including solving exercices
- be compatible with most ZIM readers
scraper
- The Python tool that build FCC ZIM. It is responsible to:- fetch FCC curriculum and package it into a proper format
- embed client can read, as well as our zim builder
Dependencies
Aside Node.JS and Python dependencies which are managed, other binary dependencies comes from Python zimscraperlib
Development
See CONTRIBUTING.md.
Prerequisites
- Node 20.x
- Python 3.11
Running scraper locally
You have to:
- build the
zimui
frontend which will be embededed inside the ZIM (and redo it every time you make modifications to thezimui
) - run the
scraper
to retrieve FCC curriculum and build the ZIM
Sample commands:
cd zimui
yarn install
yarn build
cd ../scraper
hatch run fcc2zim --language eng --course "regular-expressions,basic-javascript,basic-data-structures,debugging,functional-programming,object-oriented-programming,basic-algorithm-scripting,intermediate-algorithm-scripting,javascript-algorithms-and-data-structures-projects" --name "fcc_en_javascript" --title "freeCodeCamp Javascript" --description "FCC Javascript Courses"
Running scraper with Docker
Run from official version (published on GHCR.io) ; ZIM will be available in the output
sub-folder of current working directory.
docker run --rm -it -v $(pwd)/output:/output ghcr.io/openzim/freecodecamp:latest --language eng --course "regular-expressions,basic-javascript,basic-data-structures,debugging,functional-programming,object-oriented-programming,basic-algorithm-scripting,intermediate-algorithm-scripting,javascript-algorithms-and-data-structures-projects" --name "fcc_en_javascript" --title "freeCodeCamp Javascript" --description "FCC Javascript Courses"
Course Options and Limitations
Currently this scraper only supports Javascript challenges. A list of courses is passed to the scraper as a comma seperated list of 'course slugs'.
You can find a list of course slugs in the freeCodeCamp curriculum folder
In docker example above, see the --course
argument : regular-expressions,basic-javascript,basic-data-structures,debugging,functional-programming,object-oriented-programming,basic-algorithm-scripting,intermediate-algorithm-scripting,javascript-algorithms-and-data-structures-projects
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file fcc2zim-1.0.0.tar.gz
.
File metadata
- Download URL: fcc2zim-1.0.0.tar.gz
- Upload date:
- Size: 20.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 86dcf9e6b46059e1f8d3ad33e55a46c31510170f0254b1950d10a692cb0ef2ad |
|
MD5 | 7d78b1a042a2b38055e82aa1a4ed74c2 |
|
BLAKE2b-256 | 123d8e8484905c918680cfda22a35b38abc5d6f6b5277cdb1d729a76090cf70d |
File details
Details for the file fcc2zim-1.0.0-py3-none-any.whl
.
File metadata
- Download URL: fcc2zim-1.0.0-py3-none-any.whl
- Upload date:
- Size: 14.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f2ba3397851662e7e1b6ab7645348250efa1575a7f6cf73f18efef3462ac1509 |
|
MD5 | 77470a84d158d57562ccd996fa3cebe6 |
|
BLAKE2b-256 | f286a7ed65dc9e28e132f4e8e2bf75f8582863652e6ecbe35bf5f1f6045e1366 |