Dart implementation of KANJIDIC, a popular Kanji dictionary used by https://jisho.org/. See https://www.edrdg.org/wiki/index.php/KANJIDIC_Project.
- lists out all the characters of KANJIDIC.
- lists out ordered beginner-friendly list of Kanji.
- meanings per language.
- readings per language.
- difficulty by JLPT level and grade.
- index from 21 books.
- can also parse a custom version of KANJIDIC xml.
Add the package as a dependency.
import 'package:kanji_dictionary/kanji_dictionary.dart';
void main() async {
final kanjiDictionary = await KanjiDictionary.instance;
final character = kanjiDictionary.get('亜')!;
print(character.literal);
print(character.meanings[Language.english]);
print(character.readings[Reading.japaneseOn]);
print(character.readings[Reading.japaneseKun]);
print(character.difficulty.jlpt);
}
Prints out:
亜
[Asia, rank next, come after, -ous]
[ア]
[つ.ぐ]
1
import 'package:kanji_dictionary/kanji_dictionary.dart';
void main() async {
final kanjiDictionary = await KanjiDictionary.instance;
print(kanjiDictionary.charactersByDifficulty
.take(15)
.map((c) => c.literal)
.join(' '));
}
Prints out:
一 二 三 四 五 六 七 八 九 十 百 千 日 月 火
import 'dart:io';
main() async {
final xmlKanjidic = await File([your own kanjidic2.xml]).readAsString();
final kanjiDictionary = await KanjiDictionary.fromXml(xmlKanjidic);
}
If you want to contribute, you should clone the project, then generate kanjidic2xml.dart
by running:
dart bin/generate_kanji_dic2_const.dart