python3 requests模块_Python进阶记录之requests模块

回顾

在《Python进阶记录之HTMLParser模块》中,我们介绍了Python内置的HTML解析库HTMLParser的基本用法,并配合urllib模块和re模块实现了获取指定新闻内容的功能。今天我们讲一下Python第三方网络请求库——requests模块。

requests模块简介与安装

requests是基于Python内置的urllib模块编写而成的,采用的是Apache2 Licensed开源协议的HTTP库,requests封装了urllib库,使用起来比urllib更加方便,可以帮助我们更方便地进行网络请求。

由于requests模块不是Python内置的资源库,因此,我们需要自己去安装这个第三方库。安装方法很简单,只需使用以下命令即可。

pip install requests

当然,如果你安装了Anaconda,那么它已经帮你安装好了requests模块,直接用就可以了。另外,如果你同时安装了Python2和Python3,那么你可能需要根据开发环境选择使用pip还是pip3命令。

requests模块的简单使用

requests模块可以实现urllib模块基本上所有的功能,且使用方法更加简单。

get请求requests模块进行get请求调用get( )方法,传入url、headers等参数即可。

b03533fa828ba61e9915e8221a0e870f314e5986.jpeg?token=2cdc5b3a168c2b35489e6bbf5fcc1a25&s=C090EA3B018DC0EA484D84D30100C0B1

get请求

requests自动检测编码,使用encoding属性可以查看当前编码,我们也可以通过修改encoding属性来设置请求时使用的编码。另外,通过content属性可以获取请求结果的二进制模式,用于文件下载。

get请求也可以带参数,requests模块的get( )方法支持接收字典作为params参数将请求参数传入。

c83d70cf3bc79f3d2a1d4088f49bdd14738b294d.jpeg?token=8a1853645d480ecbf4222ae51cbe242c&s=C010ED32031B406508FC05DA0000C0B2

get请求带参数

这里我们借用httpbin这个网站,通过该网站我们可以测试HTTP请求和响应的各种信息,比如 cookie、ip、headers和登录验证等,httpbin支持GET、POST等多种请求方法。

get请求的参数会自动拼接到url后面,请求后得到相应的请求结果。如果使用urllib的get请求,我们想对请求结果进行json序列化,需要借用json模块,调用json.loads( )方法。而requests对于特定类型的响应非常方便,通过json( )方法就可以直接获取json序列化结果。

post请求requests模块进行post请求调用post( )方法,同样地,它也接收url、headers等参数。我们仍然借助httpbin网站进行post请求测试,与get方法传参使用params参数不同,post请求传参我们将待传参数的字典传给data参数。

b812c8fcc3cec3fd5880584a9bb2c43a87942716.jpeg?token=fba8c41128472fbe8433b488906d2f36&s=449A6033199FC1CE18FDA1DB000010B0

post请求

post请求参数不会拼接在url后面。此外,requests模块默认使用application/x-www-form-urlencoded格式对post数据进行编码。我们可以从返回结果中看到,请求参数在form中,并且headers头信息中的Content-Type为application/x-www-form-urlencoded。

如果我们要传递json数据,只需将原本传给data的请求参数传给json参数即可。

f703738da97739120ecc5fb8b423961d347ae2c5.jpeg?token=490f37c95c53555db291aae6d13aab17&s=4010E03319BEC4CE0AFDA1DB000080B0

传递json数据

再次运行代码,可以看到,此时请求参数在data中了,并且headers头信息中的Content-Type为application/json。

如果我们要上传一个文件到服务器,通常需要更复杂的编码格式,但是requests模块帮助我们把这种复杂的编码格式简化成了files参数。

6c224f4a20a446237490ce0fc818620b0df3d7c0.jpeg?token=651047c066a886dca9548e8089cdcd4e&s=449A7C330588514954F401DE000080B2

上传文件

使用requests模块的post( )方法,我们只需要将通过open方法打开的文件包装传递给files参数即可。

此外,requests模块对Cookie做了特殊处理。因此,使用requests模块进行网络请求时,我们不必解析Cookie就可以轻松获取到指定的Cookie信息。

50da81cb39dbb6fdc1360c50551ebb1d972b3712.jpeg?token=b21d92bfd0ed57315ab6b5c8a95ae6cf&s=C498E0330BAFC0CC54DD9DD3010080B1

Cookie

通过cookies属性,我们可以得到请求结果的Cookie。当我们知道Cookie具体信息时,还可以通过cookies['key']的方式得到指定的Cookie值,在下一次请求时就可以带上Cookie进行请求了。在编写爬虫的过程中,Cookie是我们经常使用的一个属性,我们通常会在请求时带上Cookie,具体我们在爬虫专题时再深入展开。

总结

以上内容介绍了Python第三方网络请求库requests模块的基本概念和简单用法,需要重点掌握使用requests模块进行get/post请求。requests模块是我们开发中主要的网络请求工具,在日后的学习与实际开发中会经常遇到。感谢大家的支持与关注,欢迎一起学习交流~

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值