前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >python在线抓取百度词典的翻译结果翻译单词

python在线抓取百度词典的翻译结果翻译单词

原创
作者头像
大师级码师
修改2021-11-03 13:06:07
1.6K1
修改2021-11-03 13:06:07
举报
文章被收录于专栏:大师级码师

这段代码通过抓取百度词典的翻译结果达到翻译单词的目的 这个小工具使用Python语言编写完成,其中使用到这 些类库(urllib,BeautifulSoup ),前者主要负责网络通讯方面,后者负责HTML的解析。这也是Python语言生态圈的强大之处,写个这样的小工具,毫不费力。 在线翻译的原理:首先根据用户输入的单词提交给百度词典 ,其次读取百度词典返回的数据并解析,最后将处理过的数据显示给用户。以下是该工具的具体代码(Translate.py)

代码语言:javascript
复制
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


from sharejs.com
if name=="main":
     Translate().Start()</pre> 

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档