NOTE: The project is now PAUSED, and I will not be actively mainting this project until June. I am busy with my exam-preparations for now. Sorry about this issue :-(
Please back-up your vault regularly while using this add-on!
I am a noob in programming, while no occasion of losing notes has happened, I am afraid that it might. As your notes are valuable, please do remember to back up notes.
Versions
Theoretically, it now supports Anki 2.1.26 +. I am unaware whether if supports earlier version, and I wasn't able to test it on Anki 2.1.28 as my laptop is a M1 MacBook Air and Anki 2.1.28 does not open on it.
Expectations
With this add-on, it is expected that you make all your changes in Obsidian (including the deletion, addition, and moving of the files). If you want to edit a file, you can just click on the link in Anki to link back to Obsidian. Instead of deleting files, you should move unused files into the
.trash
folder that you can turn on in the settings of Obsidian. Obsidianki will automatically remove them for you.
This is a Anki add-on that would import your files from Obsidian into Anki while preserving the wiki-links. Each file in Obsidianki will be converted to a single note in Anki. It does so by searching through your vault for the file with the name specified and generating an Obsidian url from the path.
Its github page is obsidianki4.
This add-on also works with hierarchical tags to convert the hierarchical tags in Obsidian in the metadata section (tags: [tag1/tag1.1/tag1.1.1, tag2/tag2.1/tag2.1.1]
) into anki hierarchical tags. tag1::tag1.1::tag1.1.1
and tag2::tag2.1::tag2.1.1
You can install this Add-on by downloading the obsidianki 4.ankiaddon
file from the releases section of GitHub and double click on it.
You can also download from AnkiWeb: Obsidianki 4 Addon Page. The code for this add-on is 620260832.
Before starting to use, you will have to install Obsidianki's template, without which Obsidianki would not work. To do so, go to Anki's Add-ons folder, open the folder "Obsidianki 4", and find Obsidianki 4.apkg
. Double click on it to install. You can also download it from GitHub.
After you've installed the Add-on, you can open Anki, select Tools
-> Obsidianki 4
, as shown in the following picture.
The following menu will pop-up, which will include the default preferences panel. NOTE THAT THE SETTINGS IN THIS PANEL ARE ALL DEFAULT SETTINGS, and you SHOULD NOT change them regularly, as a change will AFFECT ALL YOUR NOTES.
Copy the path of your Obsidian vault into the first field. Note that you will have to use forward slashes /
instead of backward ones for Obsidianki to function properly.
After you've set the settings (I will explain in the next section), you can click on "Save and Convert", and it will complete the conversion. However, you won't notice a difference. Why? Because Anki's interface is not refreshed. To refresh the interface, you could click on anything in Anki's main interface, and it should be refreshed.
Now, let's take a look at the default settings.
This place shows the path to your vault. Note that in order for the wiki-links in Anki to link back to Obsidian, you will have to use a path that is actually a vault. If you just copy the path of a folder in the vault, the link function will not work.
Another thing to take especial note of is that you should use forward slashes instead of backward ones.
The name of the folder in the first level that holds your templates. If specified, the contents in this folder would not be imported to Anki.
The name of the folder in the first level that holds your trash. If specified, the contents in this folder would be erased when you run the Obsidianki add-on, and the corresponding cards in anki would also be deleted.
The name of the folder in the first level that holds your archived file. If specified, corresponding anki cards to the contents in this folder would be deleted in Anki, but the files are still there in Obsidian and would not be deleted.
There are four importing cloze modes in Obsidianki.
It generates a card for every cloze. If you have 10 clozes, it generates 10 cards from {{c1::Card 1}}
to {{c10::}}
.
It generates a card for every line. If you have 10 clozes in the first line, they will be {{c1::Card 1}}
to {{c10::Card 10}}
. If you have 2 more clozes in the second line, they will be {{c2::Card 11}}
to {{c2::Card 12}}
.
It generates a card for the content under every heading, with the exception of list cards and QA cards (I will explain this below). If you have a file as below:
# Heading 1
Hello **Obsidianki**.
This is the best **Anki** add-on for importing Obsidian files into **Anki**.
## Heading 2
This is something **interesting**.
Q: What is the best add-on for importing Obsidian files into **Anki**?
A: Obsidianki!
What are the features of Obsidianki?
1. Import files
2. Preserve wiki links
3. Convert to Clozes
## Heading 3
This is **Heading 3**.
The "Obsidianki", "Anki" under "Heading 1" will be turned into {{c1::Obsidianki}}
and {{c1::Anki}}
respectively.
Theoretically, everything under "Heading 2" should be turned into {{c2::...}}
cards, right? Not quite, because I have added QA cards and list cards. So, after conversion, the portion under heading to would become:
## Heading 2
This is something **{{c2::interesting}}**.
Q: What is the best add-on for importing Obsidian files into **Anki**?
A: {{c3::Obsidianki!}}
What are the features of Obsidianki?
1. {{c4::Import files}}
2. {{c5::Preserve wiki links}}
3. {{c6::Convert to Clozes}}
In the document mode, everything will be converted to {{c1::...}}
.
There are two types in Obsidianki 4: cloze
and basic
. Nevertheless, these two types are different from Anki's cloze
and basic
.
This type will create visible deletions on the screen. You will be able to see [...]
on the screen where you applied cloze.
This type will only create one card, and the cloze deletion would not be visible.
This converts the bold syntax **bold**
to cloze in Anki, while preserving the format.
This converts the italics syntax *italics*
to cloze in Anki, while preserving the format.
This converts the highlight syntax ==highlight==
to cloze in Anki, while preserving the format.
This converts the image syntax ![]()
to cloze in Anki, while preserving the image.
This converts the quote syntax > this is a quote
to cloze in Anki, while preserving format.
Be aware that currently, this has conflicts with the other syntaxes. If you want to leave this option on, you will have to make sure that you apply no other cloze formatting in the quote.
This converts the QA syntax that I created into cloze in Anki.
Q: Question
A: Answer
Q: Question
A: {{c1::Answer}}
This turns any list into Cloze
, where each list item is a cloze.
This converts the inline code syntax to cloze in Anki, while preserving format.
This converts the block code syntax to cloze in Anki, while preserving format.
You can also individually specify the settings for each note (file) in the metadata section of your file. The metadata section is the following segment in the very beginning of a document.
---
uid: 4511487055494033182
---
By the way, Obsidianki will automatically create a metadata section that contains the file's unique id in the file. If you don't want duplicated notes, do not change the uid.
If you want to change the individual importing settings for each file, type it in in the metadata section. You can make this a template in Obsidian:
---
mode: heading
type: cloze
bold: True
italics: True
highlight: False
image: True
quote: False
QA: True
list: True
inline code: True
block code: False
---
I will try my best to develop and maintain this add-on. However, as of right now, I am just a high school student who barely knows any programming. All my knowledge of programming come from my AP Computer Science A class LOL.
I know that my code is pretty bad, so feel free to help me update them. (please do so so that I can learn from you!) I will probably add more comments to my code explaining my thoughts while writing them in the future, just in case you want to know what I did in the code. (I want to do this because I struggled to understand Anki's source code and other Add-ons). While this will not be an add-on writing tutorial and I am by no means good at python, it is my best hopes that sharing my thoughts as a beginner will help other beginners understand better how to write Anki add-ons. This will take some time for me to do, as I need to get back to work and studying, but I am going to spend some time doing so.
I want to thank the creators of Anki and Obsidian for building such beautiful apps. I also want to thank my friend Anis for helping me with the code.