This is my personal Anki CLI helper. I use it to generate/enrich my Anki notes.
It interacts with Anki using REST API exposed via AnkiConnect plugin.
- automatic text-to-speech generation using Microsoft Azure transcription.
- custom script-based note processing --- modify arbitrary fields of notes using a custom-defined script
- note type generation with meta-templating of card templates. It's useful for verb conjugation learning.
- static media files upload to Anki
- automatic cards organization: put your cards in the appropriate decks by defining organization rules.
-
Install AnkiConnect plugin.
-
Download the latest release of the tool for your platform or build it from source code using
go build .
command. -
Create your configuration file following documentation below.
-
Run Anki with AnkiConnect plugin enabled
-
Execute
path/to/anki-helper -config path/to/anki-helper.yaml
in your command line.
If you don't want to pass config file path to the tool at every execution, rename the file to anki-helper.yaml
and put it to one of the following locations:
- current work directory.
- your system's user default configuration directory, as defined by UserConfigDir.
- your user's home directory.
To see real and up-to-date example of a working configuration, check out anki-helper.yaml.
For full list of supported configuration fields, see ankihelperconf/yaml.go.
Prerequisite: in order to use text-to-speech (TTS), you need an API key to access Microsoft Azure text-to-speech service. As of 2023-01-04, you can create a free Azure Account and create a TTS resource using freebie quota. This quota is more than enough for a personal use, so you can use TTS free of charge. To generate the API key, follow the official documentation.
Once you've created a TTS resource, and chosen the voice to use, put this information into a configuration file:
azure:
# Relative path to a file that contains Azure API key.
apiKeyFile: azure-key.txt
# Endpoint URL you can find in your Azure Console.
endpointUrl: https://germanywestcentral.tts.speech.microsoft.com/cognitiveservices/v1
# Voice you want to use for TTS
voice: es-ES-AlvaroNeural
# Requests throttling. With freebie quota, TTS requests are heavily throttled on the Azure side,
# so parameters below can mitigate this Azure-side throttling.
# Feel free to remove them.
minPauseBetweenRequests: 2100ms
retryOnTooManyRequests: true
Now that you configured Microsoft Azure TTS, configure what text in what Anki notes you want to convert to speech and where you want to store that speech:
actions:
tts:
- noteFilter: 'Word:_* WordVoiceover:' # (1)
textField: Word # (2)
textPreprocessing: # (3)
- regexp: '\s+'
replacement: ' '
audioField: WordVoiceover # (4)
In the example above we told the tool to
-
Find all notes that have a non-empty field
Word
and an empty fieldWordVoiceover
. You can learn search syntax in the official documentation. -
For each note, extract
Word
field. -
Replace all substrings of the field that match
\s+
regexp with a single space character. Check out regexp syntax here -
Convert this processed text to speech and store tha audio in
WordVoiceover
field of the note.
Note: noteFilter
in the example is the default filter, so it may be omitted (the tool will automatically asume it).
You can write a custom script that processes an Anki note, and run that script against all notes matching a filter:
actions:
noteProcessing:
- noteFilter: Gender:_* -(Gender:femenino OR Gender:masculino) # (1)
exec:
command: ./normalize_gender.py # (2)
stdin: "$$ .Note.Fields | to_json $$" # (3)
args:
- "$$.Note.Fields.Gender$$" # (4)
# Fields below configure command execution throttling and timeouts.
# These fields are optional and may be omitted.
minPauseBetweenExecutions: 1200ms
timeout: 5s
The configuration above tels the tool to
-
Find all notes that have a non-empty
Gender
field that is notmasculino
orfemenino
. -
For each such note, execute the
./normalize_gender.py
program. Relative paths starting at./
or../
are resolved against configuration file directory. -
All note fields are passed to the program via stdin as a JSON object like
{"field": "value"}
. -
Gender
field of the note is passed as a first command-line argument to the program. -
Apply note modification commands that the program printed to its stdout. Sample program stdout:
[ {"set_field": {"Gender": "f"}}, {"add_tag": "gender_normalized"} ]
Supported modification commands (full list is defined in Modification struct):
{"set_field": {"field": "value"}}
{"set_field_if_empty": {"field": "value"}}
{"add_tag": "tag"}
Stdin and args may be plain text or go templates with $$
used as a delimiter.
To be documented... See a working example in anki-helper.yaml.
To be documented... See a working example in anki-helper.yaml.
To be documented... See a working example in anki-helper.yaml.
To build the tool, you need to install Go 1.17 or beyond.
Simply run go build .
to get a binary for your platform.
If you want to get binaries for different platforms, check out release.sh.
If you don't want to install Go on your system, try building the tool using Docker:
docker run --rm -v `pwd`:/projects/anki-helper -w /projects/anki-helper golang:1.17 ./release.sh
chown -R `whoami` build/
chmod -R +x build/