Skip to main content

A CLI tool to bi-directionally sync Anki notes as YAML files

Project description

Anki YAML Sync

A Python CLI tool for bi-directional syncing of Anki notes as YAML files for easy editing and version control.

Inspired by visserle/DeckOps.

Want to learn the Anki way? Download the deck.

Features

  • Bi-Directional Syncing: Import notes from Anki to YAML and export YAML back to Anki
  • Human-Readable Format: Notes are stored as YAML files for easy editing
  • Flexible: Update existing notes or create new notes (based on ID field)
  • Deck-Aware Storage: Notes are stored in folders that mirror deck nesting

Requirements

  • Anki: Running instance of Anki desktop
  • AnkiConnect: Must be installed and running on localhost:8765 (default)

To set up AnkiConnect (https://ankiweb.net/shared/info/2055492159):

  1. Open Anki > Menu Bar > Tools > Add-ons > Get Add-ons
  2. Enter the code 2055492159 and click "OK" to install AnkiConnect
  3. Restart Anki

Installation

Run the following command to install globally: pipx install anki-yaml-sync

Usage

Import Notes from Anki

Fetch all notes from Anki and save them as YAML files:

anki-yaml-sync import [--output-dir OUTPUT]

Aliases: get-from-anki, fetch, gfa, f

Options:

  • --output-dir, -o: Directory to save YAML files (default: notes)

Example:

anki-yaml-sync import --output-dir ./my-notes

Export Notes to Anki

Sync YAML files back to Anki:

anki-yaml-sync export [--input-dir INPUT] [--deck DECK]

Aliases: send-to-anki, push, sta, p

Options:

  • --input-dir, -i: Directory containing YAML files (default: notes)
  • --deck: Deck to add new notes to (default: Default)

Example:

anki-yaml-sync export --input-dir ./my-notes --deck "My Deck"

Verbose Output

Add -v or --verbose flag to any command for detailed logging:

anki-yaml-sync -v import
anki-yaml-sync -v export

YAML Format

Each note is stored as a separate YAML file. Example:

id: 1234567890
type: Basic
deck: Languages::French
tags:
  - french
  - vocabulary
fields:
  Front: Bonjour
  Back: Hello

Fields:

  • id: Anki note ID (required for updates)
  • type: Note type name (e.g., "Basic", "Cloze")
  • deck: Full deck name using :: (e.g., Parent::Child)
  • tags: List of tags to apply
  • fields: Dictionary of field names to field values

Deck Folder Structure

Deck nesting is reflected in folders. For example, a note in deck Languages::French is stored as:

notes/Languages/French/<note>.yaml

Workflow

  1. Initial Import: Run anki-yaml-sync import to create YAML files from your Anki collection
  2. Edit: Open and edit the YAML files with your text editor or IDE
  3. Sync Back: Run anki-yaml-sync export to sync your changes back to Anki

Updating Existing Notes

If a YAML file has an id field that matches an existing Anki note, the export will update that note. Fields are completely replaced (not merged).

If the YAML deck differs from the current deck, the note's cards will be moved to the YAML deck.

Creating New Notes

To create a new note:

  1. Create a new YAML file with a temporary or missing id (e.g., 0 or null)
  2. Run anki-yaml-sync export
  3. The YAML file will be automatically updated with the assigned note ID

Note: If the ID is that of an existing note, the existing note may be overwritten with the YAML file instead of creating a new note in Anki.

Contributing

See CONTRIBUTING.md for guidelines on contributing to this project and setting up development environment on your device.

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

anki_yaml_sync-0.2.3.tar.gz (14.7 kB view details)

Uploaded Source

Built Distribution

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

anki_yaml_sync-0.2.3-py3-none-any.whl (14.4 kB view details)

Uploaded Python 3

File details

Details for the file anki_yaml_sync-0.2.3.tar.gz.

File metadata

  • Download URL: anki_yaml_sync-0.2.3.tar.gz
  • Upload date:
  • Size: 14.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for anki_yaml_sync-0.2.3.tar.gz
Algorithm Hash digest
SHA256 5bddaaf25efd2c1e35f4a2acddbf7b868a667d9abd2533a28f6e4b22454ea5d7
MD5 167efa1d895c4d555b12e2c881cdd836
BLAKE2b-256 b5b8155d912bdc66a013abd298757054741a612bbd6e6a92b3edf5cc7c912093

See more details on using hashes here.

Provenance

The following attestation bundles were made for anki_yaml_sync-0.2.3.tar.gz:

Publisher: python-publish.yml on danielh-official/anki-yaml-sync

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file anki_yaml_sync-0.2.3-py3-none-any.whl.

File metadata

  • Download URL: anki_yaml_sync-0.2.3-py3-none-any.whl
  • Upload date:
  • Size: 14.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for anki_yaml_sync-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 51226702080459db68c7633b2babad19b08962147d5bfce179ac1ba3239f4cd0
MD5 2b5b611dbdd839d5c37184b79622b75c
BLAKE2b-256 a30b800aac88a3404e4be187699efbc760f1d7614c219df8bad57e429ee0f4f4

See more details on using hashes here.

Provenance

The following attestation bundles were made for anki_yaml_sync-0.2.3-py3-none-any.whl:

Publisher: python-publish.yml on danielh-official/anki-yaml-sync

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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