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.

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)

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]

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]

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
tags:
  - french
  - vocabulary
fields:
  Front: Bonjour
  Back: Hello
created: 2024-02-12T10:30:00
modified: 2024-02-12T10:30:00

Fields:

  • id: Anki note ID (required for updates)
  • type: Note type name (e.g., "Basic", "Cloze")
  • tags: List of tags to apply
  • fields: Dictionary of field names to field values
  • created: Creation timestamp
  • modified: LastModification timestamp

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).

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.1.1.tar.gz (12.6 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.1.1-py3-none-any.whl (12.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: anki_yaml_sync-0.1.1.tar.gz
  • Upload date:
  • Size: 12.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for anki_yaml_sync-0.1.1.tar.gz
Algorithm Hash digest
SHA256 9ed375832d6437dfc3a613d110ec562d36b487cd1e40b8c9c386e59fce8a35ed
MD5 f34ddb89fe5e14448069e8df4a49ecab
BLAKE2b-256 a96caaf643a38aa8f0df4e879144488ed25961de64a7abcc1582df5a30837f11

See more details on using hashes here.

File details

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

File metadata

  • Download URL: anki_yaml_sync-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 12.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for anki_yaml_sync-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 652b54f2126b8effcd51087ad6678204c8ba839cc984721f6cb102598315879d
MD5 4d4419773cd6a03e26962ebecd4227ab
BLAKE2b-256 ea929fec1a7f53f622c31dee1090f16dd3bd7e23cee8a015cadb0d53b9796c04

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