Skip to main content

CLI tool to add language learning cards to Anki

Project description

add2anki — add language study cards to Anki

PyPI version Python Version License Code style: ruff CI

A CLI tool to add language learning cards to Anki, with automatic translation and audio generation.

Currently supports English to Mandarin Chinese translation with audio generation using two providers:

  • Google Translate TTS (default, no authentication required)
  • ElevenLabs (requires API key)

For related language learning resources, visit Oliver Steele's Language Learning Resources.

Features

  • 🔄 Translate English text to Mandarin Chinese using OpenAI's GPT models
  • 🗣️ Support for different translation styles:
    • conversational (default): Natural, everyday language
    • formal: More polite expressions appropriate for business or formal situations
    • written: Literary style suitable for written texts
  • 🔊 Generate high-quality audio for Chinese text using one of two providers:
    • Google Translate TTS (default, no authentication required)
    • ElevenLabs (requires API key)
  • 🃏 Add cards to Anki with translation and audio
  • 🏷️ Add custom tags to notes or use the default "add2anki" tag
  • 🧠 Context-aware language detection that automatically identifies languages
  • 🔍 Automatic detection of suitable note types and field mappings
  • 🔧 Support for custom note types with field name synonyms (Hanzi/Chinese, Pinyin/Pronunciation, English/Translation)
  • 💾 Configuration saved between sessions
  • 📚 Support for batch processing from text, CSV/TSV, or SRT subtitle files
  • 🎬 Parse SRT files to create cards from Mandarin subtitles
  • 🤔 Interactive mode for adding cards one by one

Prerequisites

  • Python 3.11 or higher
  • Anki with the AnkiConnect plugin installed
  • OpenAI API key
  • For audio generation (optional, as Google Translate is used by default):
    • ElevenLabs API key (for ElevenLabs)

Installation

You can install add2anki using either uv, or pipx, or pip:

Using uv

  1. Install uv if you don't have it already.

  2. Install add2anki:

uv tool install add2anki

Using pipx

  1. Install pipx if you don't have it already.

  2. Install add2anki

pipx install add2anki

Using pip (not recommended)

This method doesn't require a third-party tool, but it is not recommended as it will install add2anki in the current Python environment, which may cause conflicts with other packages.

pip install add2anki

Environment Variables

Set the following environment variables:

# Required for translation
export OPENAI_API_KEY=your_openai_api_key

# Required only if using ElevenLabs
export ELEVENLABS_API_KEY=your_elevenlabs_api_key

Quick Start

# Basic usage (uses Google Translate TTS by default)
add2anki "Hello, how are you?"

# Start interactive mode
add2anki

Documentation

Note Type and Deck Selection

add2anki will automatically detect suitable note types in your Anki collection. A suitable note type must have fields that match:

  • Hanzi/Chinese/Characters for the Chinese characters
  • Pinyin/Pronunciation/Reading for the pronunciation
  • English/Translation/Meaning for the English translation

If multiple suitable note types are found, you'll be prompted to select one.

Similarly, if no deck is specified via the --deck option and no previously selected deck is found in the configuration, add2anki will display a list of available decks and prompt you to select one.

Your selections for both note type and deck will be saved for future use.

Configuration

add2anki saves your preferences (deck name, note type, field mappings) in a configuration file:

  • On Windows: %APPDATA%\add2anki\config.json
  • On macOS/Linux: ~/.config/add2anki/config.json

Acknowledgements

This project relies on several excellent libraries:

  • click for building the command-line interface
  • rich for beautiful text formatting
  • pydantic for robust data validation
  • requests for making HTTP requests

Services:

License

MIT

Author

Oliver Steele (@osteele)

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

add2anki-0.1.1.tar.gz (69.9 kB view details)

Uploaded Source

Built Distribution

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

add2anki-0.1.1-py3-none-any.whl (44.5 kB view details)

Uploaded Python 3

File details

Details for the file add2anki-0.1.1.tar.gz.

File metadata

  • Download URL: add2anki-0.1.1.tar.gz
  • Upload date:
  • Size: 69.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.2

File hashes

Hashes for add2anki-0.1.1.tar.gz
Algorithm Hash digest
SHA256 9490bce412142434a6e791df29228027b6f2411bb30c937829178ba39645eb4c
MD5 8ddd48c48f5138af06e8fb194c649457
BLAKE2b-256 b1a78955499f5db12f0f5b0d1746ec2444c6dfb0af79a11268c5ab94b9368aba

See more details on using hashes here.

File details

Details for the file add2anki-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: add2anki-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 44.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.2

File hashes

Hashes for add2anki-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 cdfcf46290f3eb8c4eaf5bace7ff36f326eb311746d663261a719e57a95805d0
MD5 6bbbd0d667eec3bfedf26a1714a5fe6a
BLAKE2b-256 38c0277b164644e06ab9adfc2b9687a80da0e61a4500ac5570674ace0004a663

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