Metadata-Version: 2.1
Name: anki_deck_from_text
Version: 1.3.6
Summary: Generate an Anki deck from annotations on a text file
Home-page: https://github.com/AndreMacedo88/anki_deck_from_text
License: MIT
Keywords: anki,flashcards,deck,language-learning
Author: Andre Macedo
Author-email: andre.lopes.macedo@gmail.com
Requires-Python: >=3.12,<4.0
Classifier: Development Status :: 4 - Beta
Classifier: Environment :: Console
Classifier: Intended Audience :: Education
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: Education
Requires-Dist: chardet (>=5.2.0,<6.0.0)
Requires-Dist: click (>=8.1.7,<9.0.0)
Requires-Dist: genanki (>=0.13.1,<0.14.0)
Project-URL: Documentation, https://andremacedo88.github.io/anki_deck_from_text/
Project-URL: Repository, https://github.com/AndreMacedo88/anki_deck_from_text
Description-Content-Type: text/markdown

# anki_deck_from_text

[![CI Tests](https://github.com/AndreMacedo88/anki_deck_from_text/actions/workflows/ci-tests.yml/badge.svg)](https://github.com/AndreMacedo88/anki_deck_from_text/actions/workflows/ci-tests.yml)
[![Docs](https://github.com/AndreMacedo88/anki_deck_from_text/actions/workflows/deploy-docs.yml/badge.svg)](https://andremacedo88.github.io/anki_deck_from_text/)
[![PyPI version](https://img.shields.io/pypi/v/anki_deck_from_text)](https://pypi.org/project/anki_deck_from_text/)
[![Python versions](https://img.shields.io/pypi/pyversions/anki_deck_from_text)](https://pypi.org/project/anki_deck_from_text/)
[![License](https://img.shields.io/github/license/AndreMacedo88/anki_deck_from_text)](https://github.com/AndreMacedo88/anki_deck_from_text/blob/main/LICENSE)

# Purpose

The purpose of this tool is to generate an Anki deck from annotations on a text file.
This was specially developed for those who use Anki to learn language vocabulary.

# Input structure

1. The input must be some sort of non-compressed text file (.txt, .md, etc.)
2. Every line to be converted to an Anki card must start with a marker, such as `-`. Use the `marker` option to set a custom marker. Every other line will be ignored.
3. The front and back of the cards are separated by a separator, such as `=`. Use the `separator` option to set a custom separator.

Example:

```
- die Katze = the cat
- das Haus = the house
```

Outside of these rules, you are free to populate your text file with other annotations which will be ignored when creating the deck.

# Current card types

Currently, the output deck will be populated with cards from one type at a time.
The currently implemented types are:

- `basic`: The [Basic](https://docs.ankiweb.net/getting-started.html#card-types) card type in Anki. Each line's text is split between front and back of one card by the `separator`
- `sound`: Similar to the [Basic (type in the answer)](https://docs.ankiweb.net/getting-started.html#card-types) card type, but with an added empty field on the back of the card that can be filled up afterwards with (for example) sound files by using an add-on such as [HyperTTS](https://ankiweb.net/shared/info/111623432). Note that this card type can also be used without filling up the sound field, thereby behaving as a `Basic (type in the answer)` card type.

# Installation

Make sure you have python installed (version >= 3.12) and then run in the terminal/command-line:

```
pip install anki_deck_from_text
```

# How to run

Open a terminal/command-line instance and follow the general structure:

```
anki_deck_from_text file_name.md output_name amazing_deck_name
```

For all options run:

```
anki_deck_from_text --help
```

You will get the following documentation:

```
Usage: anki_deck_from_text [OPTIONS] INPUT OUTPUT DECK_NAME

  Generate an Anki deck from annotations on a text file.

  INPUT is the text file. OUTPUT is the desired name for the .apkg file with
  the deck. DECK_NAME is the deck name that will be displayed in Anki.

Options:
  --version                   Show the version and exit.
  --separator TEXT            Character(s) that separate the text to be
                              written to the front and back of the cards
                              [default: =]
  --marker TEXT               Character(s) marking this line to be included in
                              the deck  [default: -]
  --card_model [basic|sound]  Anki card model to build the deck with
                              [default: basic]
  --reverse                   Swap front and back of each card
  --dry-run, --preview        Preview cards that would be generated without
                              writing a file
  --tags TEXT                 Comma-separated tags to add to all cards
  -i, --extra-input PATH      Additional input files to merge into the deck
                              (repeatable)
  -h, --help                  Show this message and exit.
```

# Further development

## Contributing

To contribute to this project:

1. [Fork](https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/working-with-forks/fork-a-repo) this project
2. Install [Poetry](https://python-poetry.org/docs/#installation)
3. Install [Nox](https://nox.thea.codes/en/stable/) (optional but recommended for automated tests and code formatting)
4. Change to the project directory and run `$ poetry install`

This should get your system setup to:

- Test that your changes didn't break the tool with `$ nox` or `$ poetry run pytest`
- Build with `$ poetry build` (optional)
- Test run with `$ poetry run anki_deck_from_text [OPTIONS] INPUT OUTPUT DECK_NAME`

Once you're happy with your changes and tests:

5. Create a [pull request](https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/creating-a-pull-request-from-a-fork) to be reviewed

## Extending the tool

### Add card types

To add extra card types follow the instructions in the `models.py` file docstring and then update the current available card types both in the docstring of `generate_deck.py` and [in the relevant section](#current-card-types) of this README.

Refer to [the Anki docs](https://docs.ankiweb.net/getting-started.html#card-types) for how to design Anki card type structures.

# Documentation

Full documentation is available at **[andremacedo88.github.io/anki_deck_from_text](https://andremacedo88.github.io/anki_deck_from_text/)**.

