更新:感谢 circlestar 更新并汉化了插件
circlestar:anki打印卡片插件(export deck to html)汉化+修bug阅读须知:本文暂时只介绍问答卡片的打印方法(实际上是因为暂时不支持填空类型卡片)
效果:可以带图片、可以保留文本样式,保存为pdf后打印即可。并且问题和答案分为左右两列,方便对折自测。
data:image/s3,"s3://crabby-images/82cf4/82cf4cf8da5b77aa5a77575b762c08fc45ba987a" alt=""
data:image/s3,"s3://crabby-images/f8ff0/f8ff07f07bbc34ff79023b4a2037dd9d875da297" alt=""
工具:Anki插件Export deck to HTML、文本编辑器、浏览器
第一步:安装插件
插件页面
Export deck to HTML插件怎么安装就不要问我了,百度一下你就知道。
第二步:筛选卡片
由于这个插件一次只能导出同一个笔记类型的卡片,所以如果你的牌组内混杂了不同类型的卡片,需要筛选出来移动到一个新的牌组中。
这里以 Anki 高考牌组为例
data:image/s3,"s3://crabby-images/914c9/914c9fd2bbb19cfae822f126545ae33cc78eaf4e" alt=""
搜索方法:在对应的牌组后面加上 "note:问答(Anki高考)" 即可筛选出该牌组中所有的 问答(Anki高考) 卡片。
将选中的卡片更换牌组,这里以 分子与细胞 为例
data:image/s3,"s3://crabby-images/52da1/52da1a528dafd276fa7abc248b3e82df5813ee13" alt=""
第三步:设置导出格式
点击主页面-左上角-工具-Export deck to html
data:image/s3,"s3://crabby-images/ecc45/ecc45db7b49dbb8bfc351a372ef0ab02089ebbda" alt=""
选择对应的牌组
data:image/s3,"s3://crabby-images/d3472/d34720edd4c42563ead203ea0c5ad10a8866ee97" alt=""
向 CSS 栏填入
table {
font-family: verdana,arial,sans-serif;
font-size:11px;
color:#333333;
border-width: 1px;
border-color: #666666;
border-collapse: collapse;
}
th {
border-width: 1px;
padding: 8px;
border-style: solid;
border-color: #666666;
background-color: #dedede;
}
td {
border-width: 1px;
padding: 8px;
border-style: solid;
border-color: #666666;
background-color: #ffffff;
}
img {
max-width: 50%;
height: auto;
}
向 html 栏填入
<tr>
<td>{{问题}}</td>
<td>{{答案}}</td>
</tr>
然后 Save,可以保存导出样式便于多次使用。最后点击 Export,导出成一个 html 文件。
第四步:后处理
用文本编辑器打开 html 文件(系统默认用浏览器,这里要右键选择编辑)
data:image/s3,"s3://crabby-images/2804a/2804a7897769cd42feaa50263388e21642554ba5" alt=""
然后找到文本中的 <body> 标签,在其下一行加入 <table>
data:image/s3,"s3://crabby-images/1e286/1e286fde18785d868b5b1c520c5ffe348143e4bd" alt=""
然后找到 </body> 同理,在其上一行加入 </table>
PS:嫌麻烦直接把body替换成table也可以
第五步:打印
这时候再用浏览器打开编辑好的 html 文件,右键后点击 Print
data:image/s3,"s3://crabby-images/808b8/808b8da329aa21ae30d3cb3b808a51ab9f318bc0" alt=""
这里可以保存为 pdf,如果你的电脑有连打印机也可以直接打印。
data:image/s3,"s3://crabby-images/091c2/091c25341fb0fe62e379ce468e2c480bb0b25448" alt=""
总结
本方法原理是利用插件,将卡片字段通过 html 和 css 重新组织为表格,然后导出后另存为 pdf 便于打印。根据不同的笔记模板,只需要制定对应的 html 和 css 即可。
可能遇上的问题
如果出现类似下面的错误,请看看你是否将 html 中的「问题」和「答案」改成你自己卡片模板对应的字段名称。
Anki 2.1.20 (47a1bf8b) Python 3.8.1 Qt 5.12.6 PyQt 5.12.3
Platform: Windows 10
Flags: frz=True ao=True sv=1
Add-ons, last update check: 2021-02-20 11:44:42
Caught exception:
Traceback (most recent call last):
File "lib\site-packages\anki\notes.py", line 144, in _fieldOrd
KeyError: '问题'
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "C:\Users\adminster\AppData\Roaming\Anki2\addons21\1897277426\ExportDeckToHtml.py", line 193, in _on_accept
value = card.note()[field[2:-2]]
File "lib\site-packages\anki\notes.py", line 149, in __getitem__
File "lib\site-packages\anki\notes.py", line 146, in _fieldOrd
KeyError: '问题'
补充
如果有卡片内含有 mathjax 格式的公式,请在第四步中继续添加以下代码至末尾:
<script type="text/x-mathjax-config">
MathJax.Hub.processSectionDelay = 0;
MathJax.Hub.Config({
messageStyle:"none",
showProcessingMessages:false,
tex2jax:{
inlineMath: [['\\(','\\)']],
processEscapes:true
}
});
</script>
<script type="text/javascript" src="https://cdn.mathjax.org/mathjax/latest/MathJax.js?config=TeX-AMS_SVG-full"></script>
然后打开html后等待渲染即可,代码参考了《ACRL:使用MathJax在AnkiDroid上显示数学公式,化学方程式》的评论区,非常感谢。
效果:
data:image/s3,"s3://crabby-images/e8bc8/e8bc8d6ae3d56265d79702a1636379d04dd0af92" alt=""
再次补充
其实填空卡片也能打印,不过暂时无法做出填空的效果。篇幅所限,下次再说。
2020/5/12 更新:后续来了
叶峻峣:【硬核】Anki2.1 打印卡片(续)——关于填空卡片转生成为复习提纲的那档事再再再次补充(感谢 @不忘初心 提供沙雕版教程)
这里有位同学遇到了如下的问题
data:image/s3,"s3://crabby-images/f1daa/f1daa179d6b729f7c12605a1596a7fba19e31043" alt=""
思考一下傻逼翻了什么罪
A. 没有认真阅读题干罪
B. 没有认真阅读材料罪
C. 没有认真阅读文章罪
无论你选哪一个,根据《关于对傻逼的处罚条例》,罪名都是成立的,我们来阅读一下总结部分(当你在阅读语文或者英语阅读时看末段也是很重要的帮你找出主旨的方法)
data:image/s3,"s3://crabby-images/15929/159298687e7a5bda2dfdcdae49bb54cf5816cd21" alt=""
不同的笔记模板,就要更改不同的html代码,以系统自带的“基础“”为例子,你制成的卡片是这样的
data:image/s3,"s3://crabby-images/0d265/0d265b4f5e133d7f4de2508e3e9d240473c0648d" alt=""
那么你的html代码是这样的
data:image/s3,"s3://crabby-images/e27b8/e27b8e7bd34805a4879280df2ad787671a085a3a" alt=""
你要根据每个子标题去更改双大括号里的内容,如果我表达的不太准确,大家也可以根据下面的这个例子来尝试举一反三一下
data:image/s3,"s3://crabby-images/70c16/70c1605ebd1ce0c64ac7f646bd0523a821be8e81" alt=""
data:image/s3,"s3://crabby-images/ab0e2/ab0e2bd66492b78943a1f1cdb21bb54a6ed26354" alt=""