【python爬虫小实战】python3.x用requests和bs4实现有道翻译(中英文)

一直用的是python3.x版本的,刚开始学爬虫的时候学长给了我个爬有道翻译的小程序,实现中英文翻译,由于是用urllib库的,当时也是刚接触python,所以一脸懵逼,现在学了一个月了,回头再看了一下,感觉很时间单,于是就用requests库和bs4,加上json网页解析,也写 了个翻译小程序,(感觉比用urllib代码要少的多,)其实开始requests.get的方法参数很懵逼,百度了一下,总算把这点弄明白。越发感觉python库的强大

#python 爬虫有道翻译
import requests
from bs4 import BeautifulSoup
import json
while True:

    content = input('请输入要查询的单词/词语(输入0退出翻译):')
    if content == '0':
        print('欢迎下次使用!')
        break
    url = 'http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule&sessionFrom=null'
    headers = {
        'User-Agent':'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/59.0.3071.115 Safari/537.36'
        ,'from':'AUTO',
        'to':'AUTO',
        'smartresult':'dict',
        'client':'fanyideskweb',
        'doctype':'json',
        'version':'2.1',
        'keyfrom':'fanyi.web',
        'action':'FY_BY_ENTER',
        'typoResult':'true',
        'i':content
        ,'ue':'UTF-8'#设置翻译支持中文

    }


    res = requests.get(url,params = headers)
    soup = BeautifulSoup(res.text,'lxml')
    jd = json.loads(soup.text)

    print('翻译结果:')
    for translate in jd['smartResult']['entries']:
        print(translate)
    print('\n')

退出测试
翻译测试
代码很简单,很容易就能明白的,欢迎大佬们测试(#滑稽)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值