快速零散制卡
在添加卡片和编辑卡片界面,插件辅助完成单词释义的查询和自动填充。
批量制卡
在浏览器界面选择多个单词,插件辅助完成选中单词释义的批量查询和自动填充。
本地词典支持
支持mdx格式词典和stardict格式词典。
网络词典支持
支持网络词典的查询,目前内置有道、百词斩等插件。
所有词典以插件形式实现,用户可自行定义、修改和删除。插件定义和实现方式可参考该节。
https://github.com/finalion/WordQuery下载并放到anki插件文件夹
安装代码775418273
“工具”菜单-->"WordQuery",弹出设置界面;
点击“词典文件夹”按钮,在弹出的对话框中通过“+”或“-”增加或删除文件夹,支持递归查找。
其他设置
使用文件名作为词典名:不选中则使用词典中的特定标题字段作为词典名
导出媒体文件:选中则导出词典解释中包含的音频
在设置界面中,点击“选择笔记类型”按钮,选择要设定的笔记类型;
单选框选中要查询的单词字段.
为每个笔记区域映射待查询的词典以及词典字段:
词典下拉框选项中包括三部分,各部分之间有分割线:
第一部分:“不是词典字段”
第二部分:设定文件夹中包含的可支持的本地词典
第三部分:网络词典
插件可在多种编辑模式下快速查询并添加单词释义。
“添加笔记”界面和“编辑笔记”界面
点击“Query”按钮查询并填充全部字段的释义;
右键菜单“Query All Fields”查询并填充全部字段的释义;
右键菜单“Query Current Field”查询并填充当前字段的释义;
右键菜单“Options”查看修改笔记区域和词典字段的映射;
浏览器
所有操作均支持快捷键,默认为"Ctrl+Q",可修改。
“工具”菜单-->“插件”-->"wordquery"-->编辑,找到并修改快捷键设置:
# shortcut
shortcut = 'Ctrl+Q'
继承WebService,使用@register(label)
装饰。参数label
作为词典标签,出现在词典下拉列表中。例如
@register(u'有道词典')
class Youdao(WebService):
"""service implementation"""
如果不注册label
,则默认使用类名称作为标签。
词典字段导出函数返回查询词典相应字段的释义,使用@export(fld_name, order)
装饰。
参数fld_name
为词典字段名称,出现在词典字段下拉列表中
参数order
为词典字段在下拉列表中的顺序,小号在上,大号在下,但号码无需连续。
例如,
@export(u'美式音标', 1)
def fld_phonetic_us(self):
return self._get_field('phonitic_us')
@export(u'英式音标', 2)
def fld_phonetic_uk(self):
return self._get_field('phonitic_uk')
使用@with_style(**kwargs)
修饰导出词典字段函数,支持参数包括,
cssfile
词典(字段)使用的css文件,需放置在service
模块的static
文件夹下。
css
词典(字段)使用的css字符串。
jsfile
词典(字段)使用的js文件,需放置在service
模块的static
文件夹下。
js
词典(字段)使用的js字符串。
need_wrap_css
为了避免不同字典css样式命名重复可能带来的样式混乱,设置该参数为True
,插件可通过添加全局div
对样式表和词典释义结果进行包装。需要定义添加的全局div
的类名wrap_class
。
包装之后的css文件为*orig_name*_wrap.css
。
目前包装方法比较粗糙,待持续验证和改进。
wrap_class
全局div
类名,need_wrap_css
为True
时有效。
例如,
@with_styles(cssfile='_youdao.css', need_wrap_css=True, wrap_class='youdao')
def _get_singledict(self, single_dict, lang='eng'):
url = "http://m.youdao.com/singledict?q=%s&dict=%s&le=%s&more=false" % (
self.word, single_dict, lang)
try:
return urllib2.urlopen(url, timeout=5).read()
except:
return ''
为了避免对网络词典服务的重复查询,可在必要时对中间结果进行缓存。方法包括,
cache_this(result)
缓存当前结果。
cached(key)
检查key
是否被缓存。
cache_result(key)
返回缓存结果。
具体可参考有道词典 youdao.py实现方式。