VerbForm is a powerful Python-based tool designed to help language learners quickly create Anki flashcards for German verbs. With just a few commands, you can transform verb information from verbformen.de into beautiful, informative Anki cards.
- 🤖 Automatic verb data extraction
- 📇 One-click Anki card creation
- 🔊 Includes audio pronunciations
- 🌈 Customized, visually appealing card design
- 🌍 Multilingual support
Before you begin, ensure you have:
- Python 3.8+
- Anki Desktop installed
- A passion for learning German! 🇩🇪
-
Clone the repository:
git clone https://github.com/kmoragap/verbform.git cd verbform
-
Install required dependencies:
pip install -r requirements.txt
Before using VerbForm, you MUST configure the config.py
file carefully. Here's a step-by-step walkthrough:
You need to specify the exact paths to your Anki collection:
ANKI_COLLECTION_PATH
: The path to your Anki collection fileANKI_MEDIA_PATH
: The path to your Anki media folder
🔍 How to Find Your Paths:
- For macOS:
/Users/[YourUsername]/Library/Application Support/Anki2/[Profile Name]/
- For Windows:
C:\Users\[YourUsername]\AppData\Roaming\Anki2\[Profile Name]\
- For Linux:
~/.local/share/Anki2/[Profile Name]/
🌐 Helpful Resources:
DECK_NAME
: The name of the Anki deck where cards will be added- Can be an existing deck
- Or create a new deck by simply entering a new name
MODEL_NAME
: The type of note template- Default is "Basic" (English)
- Varies by Anki's language setting, e.g.:
- Spanish: "Básico"
- French: "Basique"
🌍 Tip: Check your Anki's note type name in the card type manager.
LANGUAGE
: Set the language code for translations'es'
for Spanish'fr'
for French'en'
for English- etc.
Create Anki cards for verbs directly from the command line:
python main.py machen lernen spielen
To add a noun to your Anki deck, use the --noun
flag:
python3.12 main.py --noun <noun>
Example:
python3.12 main.py --noun libro
Use the --reverse
and/or --cloze
flags to generate multiple cards from the noun. Reverse will flip front and back for better recall. Cloze will create a cloze on (1) der/die/das, (2) genitive case, and (3) plural form
Example:
python3.12 main.py --noun libro --reverse --cloze
To add an adverb to your Anki deck, use the --adverb
flag:
python3.12 main.py --adverb <adverb>
Example:
python3.12 main.py --adverb gern
To add an adjective to your Anki deck, use the --adjective
flag:
python3.12 main.py --adjective <adjective>
Example:
python3.12 main.py --adjective ganz
- Add a single verb:
python main.py lernen
- Add multiple verbs:
python main.py machen spielen gehen
- Use the
--reverse
and/or--cloze
flags to generate multiple cards from the verb. Reverse will flip front and back for better recall. Cloze will create a cloze on (1) 3rd person Präsens, (2) 3rd person Präteritum, and (3) past Partzip
Example:
python3.12 main.py lernen --reverse --cloze
- Close Anki before running the script
- Ensure you have the correct Anki deck and model set in
config.py
Edit config.py
to customize:
- Anki collection path
- Deck and model names
- Language settings
- Theme colors
The card_template.py
allows you to modify the visual style of your Anki cards. Adjust colors, fonts, and layout to suit your learning style!
Translations currently tested in:
- Spanish (es)
- French (fr)
- English (en)
But it should work for all languages 😁.
Set your preferred language in config.py
Love VerbForm? Help us make it better!
- ⭐ Star the repository
- 🐛 Report issues
- 🚀 Submit pull requests
- Create web interface
- New card templates
🌈 Happy Learning! Made with ❤️ by German Language Enthusiast