Anki.NET
2.0.0
dotnet add package Anki.NET --version 2.0.0
NuGet\Install-Package Anki.NET -Version 2.0.0
<PackageReference Include="Anki.NET" Version="2.0.0" />
paket add Anki.NET --version 2.0.0
#r "nuget: Anki.NET, 2.0.0"
// Install Anki.NET as a Cake Addin #addin nuget:?package=Anki.NET&version=2.0.0 // Install Anki.NET as a Cake Tool #tool nuget:?package=Anki.NET&version=2.0.0
Anki.NET
Create and export Anki collections, decks, notes and cards from your C# applications.
var noteType = new AnkiNoteType(
name: "Basic",
cardTypes: new[] {
new AnkiCardType(
Name: "Card 1",
Ordinal: 0,
QuestionFormat: "{{Front}}",
AnswerFormat: "{{Front}}<hr id=\"answer\">{{Back}}"
)
},
fieldNames: new[] { "Front", "Back" }
);
var collection = new AnkiCollection();
var noteTypeId = collection.CreateNoteType(noteType);
var deckId = collection.CreateDeck("My Anki Deck");
collection.CreateNote(deckId, noteTypeId, "Hello", "Bonjour");
await AnkiFileWriter.WriteToFileAsync("MyCollection.apkg", collection);
Acknowledgement
Anki.NET is a fork form the the archived AnkiSharp project from Clement-Jean. Thanks a lot for the hard work!
Usage
AnkiCollection
Start by creating an AnkiCollection
. To add notes to the collection, you need a notes model (AnkiNoteType
), you can pass in the constructor, like this.
A note can correspond to one or several cards, if their model has several card tempates ('AnkiCardType').
var cardTypes = new[]
{
new AnkiCardType(
"Forwards",
0,
"{{Front}}<br/>{{hint:Help}}",
"{{Front}}<hr id=\"answer\">{{Back}}"
),
new AnkiCardType(
"Backwards",
1,
"{{Back}}<br/>{{hint:Help}}",
"{{Back}}<hr id=\"answer\">{{Front}}"
)
};
var noteType = new AnkiNoteType(
"Basic (With hints)",
cardTypes,
new[] { "Front", "Back", "Help" }
);
var collection = new AnkiCollection();
var noteTypeId = collection.CreateNoteType(noteType);
AnkiDeck
var collection = new AnkiCollection();
var deckId = collection.CreateDeck("French vocabulary");
bool deckExists = collection.TryGetDeckById(deckId, out var deck);
AnkiNote
With the above AnkiNoteType
(which has two card types), each added note will generate 2 different cards.
collection.CreateNote(deckId, notetypeId, "Hello", "Bonjour", "");
collection.CreateNote(deckId, noteTypeId, "House", "Maison", "Starts with \"M\"");
Set CSS
var noteType = new AnkiNoteType(
name: "Basic",
cardTypes: cardTypes,
fieldNames: names,
css: @".card{
color: red;
}",
);
Read AnkiCollection
from .apkg
file
AnkiCollection collection = await AnkiFileReader.ReadFromFileAsync("collection.apkg");
Write AnkiCollection
to .apkg
file
var collection = new AnkiCollection();
await AnkiFileWriter.WriteToFileAsync("MyCollection.apkg", collection);
Resources
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
-
net7.0
- Microsoft.Data.Sqlite (>= 7.0.10)
- ZstdSharp.Port (>= 0.7.2)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.