- Python HTTP请求的实现 [ 笔记 ]

目录

安装Requests库

GET请求

POST请求 

响应码code和响应头headers的处理

请求超时设置


读取URL和下载网页内容,是每一个爬虫的必经之路。那么在阅读《Python爬虫开发与项目实战》一书得知,Python实现HTTP请求有三种方式——

  1. urllib2/urllib
  2. httplib/urllib
  3. Requests

经书中例子对比发现,个人更偏好第三种请求方式,操作比较简单,因为懒,所以这里对前两种方式不做过多的赘述,有兴趣的小伙伴自己去百度吧,反正我的懒癌已经是晚期无解了。那么接下来——

 

安装Requests库

由于Requests是一个第三方库,所以在使用之前,需要先安装它,在线安装pip一下,一切都是那么的完美,当然了,不要在意我的Python版本,毕竟整个公司用到都是2.7我能怎么办呢 ——

安装成功之后,跟着书中的例子敲一遍吧

 

GET请求

# -*- coding:utf-8 -*-
import requests

# 以下为GET请求
url = 'https://www.csdn.net/'
requests = requests.get(url)
print requests.content  # 返回字节形式

 

POST请求 

# -*- coding:utf-8 -*-
import requests

# 以下为POST请求
url = 'https://xxxxx.com/login'
postdatas = {'key': 'value'}
requests = requests.post(url, data=postdatas)
print requests.content  # 返回字节形式

然后其他的put、delete等方法,也可以照葫芦画瓢的使用

 

响应码code和响应头headers的处理

# -*- coding:utf-8 -*-
import requests

url = 'https://www.csdn.net/'
r = requests.get(url)
if r.status_code == requests.codes.ok:
    print '=== status_code === ', r.status_code  # 响应码
    print '=== headers === ', r.headers  # 响应头
    print '=== Content-Type === ', r.headers.get('Content-Type')  # 获取响应头中的Content-Type字段
else:
    r.raise_for_status()  # 抛出异常

打印结果如下:

 

请求超时设置

# -*- coding:utf-8 -*-
import requests

url = 'https://www.csdn.net/'
r = requests.get(url,timeout=20)

 timeout的单位为秒

  • 5
    点赞
  • 51
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Python中有多种库可以用于进行HTTP请求,包括httpx、urllib、urllib3和requests等。httpx是Python的新一代网络请求库,它是基于Python3的功能齐全的http请求模块,支持发送同步和异步请求,同时支持HTTP/1.1和HTTP/2协议,并且可以直接向WSGI应用程序或ASGI应用程序发送请求。 另外,urllib、urllib3和requests也是常用的Python库,用于进行HTTP请求。urllib是Python标准库中的一个模块,提供了一些基础的HTTP请求功能;urllib3是一个功能强大的HTTP客户端库,提供了更高级的功能,如连接池和重试机制;而requests是一个非常流行的第三方库,提供了简洁易用的API,使得发送HTTP请求变得更加方便。 通过使用这些库,你可以轻松地在Python中进行HTTP请求,从而调用API、获取网页内容或与服务器进行通信。这些库都有详细的文档和示例,可以帮助你更好地理解和使用它们。最终选择哪个库,取决于你的需求和个人偏好。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Python Http请求浅析](https://blog.csdn.net/m0_57081622/article/details/125173593)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [Python笔记.docx](https://download.csdn.net/download/bxy0806/88235414)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值