使用Python从有道词典网页获取单词翻译

时间:2021-05-22

从有道词典网页获取某单词的中文解释。

import reimport urllibword=raw_input('input a word\n') url='http://dict.youdao.com/search?q=%s'%word content=urllib.urlopen(url) pattern=re.compile("</h2.*?</ul>",re.DOTALL) result=pattern.search(content.read()).group()pattern2=re.compile('<li>.*?</li>')for i in pattern2.findall(result): print i.strip('<li>').strip('</li>').decode('utf-8')

再给大家分享一个命令行版的

#!/usr/bin/env python# -*- coding: utf-8 -*-# @Date : 2014-04-03 21:12:16# @Function: 有道翻译命令行版# @Author : BeginManimport osimport sysimport urllibimport urllib2reload(sys)sys.setdefaultencoding("utf-8")import simplejson as jsonimport platformimport datetimeAPI_KEY = '******'KEYFORM = '******' def GetTranslate(txt): url = 'http://fanyi.youdao.com/openapi.do' data = { 'keyfrom': KEYFORM, 'key': API_KEY, 'type': 'data', 'doctype': 'json', 'version': 1.1, 'q': txt } data = urllib.urlencode(data) url = url+'?'+data req = urllib2.Request(url) response = urllib2.urlopen(req) result = json.loads(response.read()) return result def Sjson(json_data): query = json_data.get('query','') # 查询的文本 translation = json_data.get('translation','') # 翻译 basic = json_data.get('basic','') # basic 列表 sequence = json_data.get('web',[]) # 短语列表 phonetic,explains_txt,seq_txt,log_word_explains = '','','','' # 更多释义 if basic: phonetic = basic.get('phonetic','') # 音标 explains = basic.get('explains',[]) # 更多释义 列表 for obj in explains: explains_txt += obj+'\n' log_word_explains += obj+',' # 句子解析 if sequence: for obj in sequence: seq_txt += obj['key']+'\n' values = '' for i in obj['value']: values += i+',' seq_txt += values+'\n' print_format = '*'*40+'\n' print_format += u'查询对象: %s [%s]\n' %(query,phonetic) print_format += explains_txt print_format += '-'*20+'\n'+seq_txt print_format += '*'*40+'\n' print print_format choices = raw_input(u'是否写入单词本,回复(y/n):') if choices in ['y','Y']: filepath = r'/home/beginman/pyword/%s.xml' %datetime.date.today() if (platform.system()).lower() == 'windows': filepath = r'E:\pyword\%s.xml' %datetime.date.today() fp = open(filepath,'a+') file = fp.readlines() if not file: fp.write('<wordbook>\n') fp.write(u""" <item>\n <word>%s</word>\n <trans><![CDATA[%s]]></trans>\n <phonetic><![CDATA[[%s]]]></phonetic>\n <tags>%s</tags>\n <progress>1</progress>\n </item>\n\n""" %(query,log_word_explains,phonetic,datetime.date.today())) fp.close() print u'写入成功.'def main(): while True: txt = raw_input(u'请输入要查询的文本:\n') if txt: Sjson(GetTranslate(txt))if __name__ == '__main__': main()

以上就是本文的所有内容了,希望大家能够喜欢

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章