摘自 http://github.com/panweizeng/home/blob/master/code/python/dict/dict.py 支持简单的Ch to En 和En to Ch我把它放在 /usr/bin/dict 1234567891011
$ dict 白痴
单词:白痴 音标: bái chī 释义:idiot idiocy 例句:他很聪明,但有时举止像是白痴。 翻译:He is intelligent, but sometimes he behaves like an idiot. 例句:我不讳言,我说过他是白痴。 翻译:I didn‘t mince matters: I said he was an idiot. 例句:真是白痴一个! 翻译:What a stupid idiot!
#!/usr/bin/python #coding=utf8 import urllib import sys import os import re import xml.dom.minidom as xml #API_URL = ‘http://dict.cn/ws.php?utf8=true&q=%s‘ API_URL = ‘http://dict-co.iciba.com/api/dictionary.php?w=%s‘ def getword(word): xmls = urllib.urlopen(API_URL%urllib.quote(word)).read() #print xmls root = xml.parseString(xmls).documentElement #print re.sub(u‘>‘, ‘>\n‘,xmls) #tags = {‘key‘:‘单词‘, ‘pron‘:‘音标‘, ‘def‘:‘释义‘, ‘sent‘:‘例句‘, ‘orig‘:‘例句‘, ‘trans‘:‘翻译‘, ‘acceptation‘:‘释义‘} tags = {‘key‘:‘单词‘, ‘ps‘:‘音标‘, ‘def‘:‘释义‘, ‘sent‘:‘例句‘, ‘orig‘:‘例句‘, ‘trans‘:‘翻译‘, ‘acceptation‘:‘释义‘} def isElement(node): return node.nodeType == node.ELEMENT_NODE def isText(node): return node.nodeType == node.TEXT_NODE def show(node, tagName=None): if isText(node): tag = tags.get(tagName, tagName) print ‘%s:%s‘%(tag, node.nodeValue) elif isElement(node) and tags.has_key(node.tagName): [show(i, node.tagName) for i in node.childNodes] [ show(i) for i in root.childNodes if isElement(i) ] def main(): if len(sys.argv) >= 2: word = ‘ ‘.join(sys.argv[1:]) getword(word) os.system(‘say %s‘ % word); else: print ‘usage:dict [word]‘ if __name__ == ‘__main__‘: reload(sys) sys.setdefaultencoding(‘utf8‘) main()
时间: 2024-12-19 16:26:20