Skip to main content

Command-line tool for adding flashcards from Markdown files to Anki

Project description

inka2

Downloads PyPi Tests CI Codecov

Automatically extract flashcards from Markdown to Anki.

too useful to let it be unsupported :-)

Installation

Install inka2:

python3 -m pip install inka2 --upgrade

Requirements

Why

I've been using Anki for a long time, and at some point my notes turned into just lists of question/answer pairs, from which I then created Anki cards. The process of creating flashcards in Anki took a long time, so I decided to write a Python script to automate it. With more and more features added, the script has evolved into the command-line tool you can see now.

inka2 allows you to use full power of Markdown when creating flashcards. The program is also extensively tested.

Features

nvim Integration

For better card management in your markdown files the inka-nvim plugin might be helpful.

Usage

Creating Cards

In order for the program to be able to separate cards from all the rest of the text in the file, you need to enclose them between two ---:

---

Deck: Life Questions

Tags: learning life-questions

1. What is the answer to the Ultimate Question of Life, the Universe, and Everything?

> 42

2. If it {{c1::looks like a duck, swims like a duck, and quacks like a duck}}, then it is a {{c2::duck}}.

---

You can create any number of such sections in the file.

:warning: This means that you should avoid using the --- syntax anywhere else in the file for inka2 to work correctly. There are exceptions, and you can read about them in documentation.

Inside the section, you can specify the name of the deck to which the cards will be added, and tags for the cards. If deck name isn't specified, then the one from the config is used (Default by default). The deck name is written after Deck:, and tags for all cards after Tags: with spaces between each tag.

Two types of notes are supported:

  • Front/Back: every question starts with number followed by period (e.g. 1., 2. - Markdown ordered list syntax) and every line of the answer starts with > (Markdown quote syntax). Question and answer can span multiple lines.
  • Cloze: same as Front/Back notes, Cloze notes start with number followed by period (Markdown ordered list syntax). inka2 supports three versions of syntax for cloze deletions:
    • Anki syntax: {{c1::hidden text}}
    • Short explicit syntax: {1::hidden text} or {c1::hidden text}
    • Short implicit syntax: {hidden text}

More info and examples on the creating cards documentation page.

Adding Cards to Anki

inka2 will create custom note types for Front/Back and Cloze notes. If you want to use different ones, you can change note types in the config.

Add cards from the file:

inka2 collect path/to/cards.md

Or from all Markdown files in a directory:

inka2 collect path/to/directory

You can also pass multiple paths at once:

inka2 collect path/to/cards.md path/to/folder

You can find more information on the documentation page.

Configuration

inka2 can be customized via a config.ini file. Key configuration options include:

Styling Options

[highlight]
style = monokai                    # Syntax highlighting theme
inline_code_color = #8b5cf6        # Inline code color (default: #fa4545)

The inline_code_color option allows you to customize the color of inline code elements in your Anki cards. You can use any valid CSS color value (hex, rgb, named colors, etc.).

For complete configuration options, see the Config documentation.

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

inka2-3.2.2.tar.gz (53.1 kB view details)

Uploaded Source

Built Distribution

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

inka2-3.2.2-py3-none-any.whl (43.5 kB view details)

Uploaded Python 3

File details

Details for the file inka2-3.2.2.tar.gz.

File metadata

  • Download URL: inka2-3.2.2.tar.gz
  • Upload date:
  • Size: 53.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.5

File hashes

Hashes for inka2-3.2.2.tar.gz
Algorithm Hash digest
SHA256 d1651b76a06af0e12d5067ce91159327b96eea560d3eeef0e3f7f871710a5623
MD5 34982eaaf49e486d72b69d6256d4e150
BLAKE2b-256 85dcff2c169f98374a17fe31947dcde781f883b3b9a01721d6e2f43126ce4525

See more details on using hashes here.

File details

Details for the file inka2-3.2.2-py3-none-any.whl.

File metadata

  • Download URL: inka2-3.2.2-py3-none-any.whl
  • Upload date:
  • Size: 43.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.5

File hashes

Hashes for inka2-3.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 9d2a0cbcde0983d1e5abe2e96b92b8504bd04883df8e98d7236aebf19d54d3a0
MD5 7cd6a4d911938d102fa59631bacc2452
BLAKE2b-256 9881d37746cf59e5508165439749beefa3f2d131c654ee8b526f5cebd5975aea

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