python学习笔记之模块爬虫-实战(十二)

一.python如何访问互联网

1.1 urllib模块介绍

url + lib 组成了urllib模块

通过urllib访问百度首页示例:

>>> import urllib.request as req
>>> response = req.urlopen('http://www.baidu.com')
>>> html = response.read()
>>> html = html.decode('utf-8')
>>> print(html)

1.2 爬取一只猫的图片

访问http://placekitten.com网站,获取一张600*800的jpg图片
示例代码如下:

import urllib.request
#获取request
request = urllib.request.Request("http://placekitten.com/g/600/800")
#得到响应
response = urllib.request.urlopen(request)
#获取图片
cat_img = response.read()
#图片写到本地文件
with open('cat_600_800.jpg','wb') as f:
    f.write(cat_img)

在这里插入图片描述

二.通过有道词典来翻译

2.1 查看网页版有道词典

在浏览器中输入:http://fanyi.youdao.com/,同时按下F12,打开开发者工具
查看network页签中的内容,如下图
在这里插入图片描述
查看http://fanyi.youdao.com/translate_o?smartresult=dict&smartresult=rule 请求页签中的request url和from data区域
from data

2.2 通过python来实现翻译

import urllib.request
import urllib.parse
import json

content=input('Enter the word that needs translated:')
#http://fanyi.youdao.com/translate_o?smartresult=dict&smartresult=rule
#translate_o要改成translate
url = 'http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule'
data = {}
data['i'] = content
data['from'] = 'AUTO'
data['to'] = 'AUTO'
data['smartresult'] = 'dict'
data['client'] = 'fanyideskweb'
data['salt'] = '15893844176578'
data['sign'] = '33d74a960c3e39c6eb93bc725324a233'
data['ts']='1589379361257'
data['bv']='0ea2f265e69dc7094ed5f0b64ef39e0b'
data['doctype'] = 'json'
data['version'] = '2.1'
data['keyfrom'] = 'fanyi.web'
data['action'] = 'FY_BY_REALTlME'

data = urllib.parse.urlencode(data).encode('utf-8')

response = urllib.request.urlopen(url,data)

html = response.read().decode('utf-8')

target=json.loads(html)
print('result:%s'%(target['translateResult'][0][0]['tgt']))

http://fanyi.youdao.com/translate_o?smartresult=dict&smartresult=rule请求的url中需去掉_o

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值