闲来无事,用Python写个翻译工具
时间:2011-03-15
来源:互联网
在英语词典方面,Linux环境下的软件远不及Win环境下,由于工作一般都在Linux环境下,并且希望在堆码的时候不用离开vim编辑器,于是花了一点时间写了个翻译的小工具,主要方便我在Linux环境下遇到不认识的英语单词时充当翻译小助手。这个小工具使用Python语言编写完成,其中使用到这些类库(urllib,BeautifulSoup ),前者主要负责网络通讯方面,后者负责HTML的解析。这也是Python语言生态圈的强大之处,写个这样的小工具,毫不费力。
在线翻译的原理:首先根据用户输入的单词提交给百度词典 ,其次读取百度词典返回的数据并解析,最后将处理过的数据显示给用户。以下是该工具的具体代码(Translate.py):
复制代码
在线翻译的原理:首先根据用户输入的单词提交给百度词典 ,其次读取百度词典返回的数据并解析,最后将处理过的数据显示给用户。以下是该工具的具体代码(Translate.py):
- import urllib
- import codecs
- from BeautifulSoup import BeautifulSoup
- from sys import argv
- import re,time
-
- class Translate:
- def Start(self):
- self._get_html_sourse()
- self._get_content("enc")
- self._remove_tag()
- self.print_result()
-
- def _get_html_sourse(self):
- word=argv[1] if len(argv)>1 else ''
- url="http://dict.baidu.com/s?wd=%s&tn=dict" % word
- self.htmlsourse=unicode(urllib.urlopen(url).read(),"gb2312","ignore").encode("utf-8","ignore")
-
- def _get_content(self,div_id):
- soup=BeautifulSoup("".join(self.htmlsourse))
- self.data=str(soup.find("div",{"id":div_id}))
-
- def _remove_tag(self):
- soup=BeautifulSoup(self.data)
- self.outtext=''.join([element for element in soup.recursiveChildGenerator() if isinstance(element,unicode)])
-
- def print_result(self):
- for item in range(1,10):
- self.outtext=self.outtext.replace(str(item),"\n%s" % str(item))
- self.outtext=self.outtext.replace(" ","\n")
- print self.outtext
-
- if __name__=="__main__":
- Translate().Start()
作者: boy11-2 发布时间: 2011-03-15
如果您的运行环境安装了BeautifulSoup类库,那么执行类似这样的命令
ython Translate.py computer,您将会看到下面这样的结果:
后记,目前这个小工具在输出排版方面还不太满意。

后记,目前这个小工具在输出排版方面还不太满意。
作者: boy11-2 发布时间: 2011-03-15
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28