055/056_爬虫_urllib_下载/请求对象的定制

下载案例

import urllib.request
# 网页下载
url_page = "http://www.baidu.com"
urllib.request.urlretrieve(url_page,"baidu.html")

# 图片下载
url_img = "https://pic2.zhimg.com/v2-a4619293e8e376f5ee1fc1dd616b4197_r.jpg?source=1940ef5c"
urllib.request.urlretrieve(url_img,"duolaameng.jpg")

# 视频下载
url_video = "https://vd2.bdstatic.com/mda-ikvdq36633tc3bwu/sc/mda-ikvdq36633tc3bwu.mp4?v_from_s=hkapp-haokan-hnb&auth_key=1652528717-0-0-8ae606a3eb512f1a5b1216e2cde9709b&bcevod_channel=searchbox_feed&pd=1&cd=0&pt=3&logid=0916865844&vid=15764645099659448706&abtest=101830_2-102133_1-102148_1-17451_2&klogid=0916865844"
urllib.request.urlretrieve(url_video,"yanhua.mp4")

请求对象的定制

url的组成

https://www.baidu.com/s?wd=周杰伦

http/httpswww.baidu.com80/443swd=周杰伦#
协议主机端口号路径参数锚点

端口号

httphttpsmysqlOracleredismongodb
8044333061521637927017

import urllib.request
url = "http://www.baidu.com"
headers = {
    "User-Agent": "Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; Trident/4.0; SE 2.X MetaSr 1.0; SE 2.X MetaSr 1.0; .NET CLR 2.0.50727; SE 2.X MetaSr 1.0)"
}
# 因为urlopen方法中不能储存字典 所有hraders不能传递进去
# 请求对象的定制
# 注意 因为参数顺序的问题  不能直接写url和headers    中间还有个data 所有我们需要关键字传递
request = urllib.request.Request(url=url,headers=headers)
response = urllib.request.urlopen(request)
content = response.read().decode("utf-8")
print(content)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值