Python Httpx库实现超跑式网络请求用法实例

 更新时间:2024年01月22日 08:46:25   作者:晓飞的李 管窥程序  
这篇文章主要为大家介绍了Python Httpx库实现超跑式网络请求用法实例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

引言

想象一下,你正急于抓取一个网站上的最新数据,在编码的世界中翻飞而行,便捷高效是你处理任务时最看重的特质。

在一个如同大都市拥挤不堪的网络中,你需要一辆能够轻巧穿梭并且强大可靠的"跑车",那就必须是一个优秀的 HTTP 客户端库。

过去,requests 凭借其简洁和易用性成为了你的首选。但现在,httpx 脱颖而出,就像是一辆装有涡轮增压的跑车,它提供了解决现代网络挑战所需要的所有新功能和性能提升 —— 包括但不限于异步支持、HTTP/2、连接超时等。如果你希望自己的网络请求像运动跑车一样,那么 httpx 无疑是你的不二选择。

什么是 httpx?

httpx 是一个现代化的 HTTP 客户端,由 Tom Christie 领导开发,他同样是著名的 Django REST framework 的原作者。httpx 开源项目旨在提供一个功能丰富,使得发送 HTTP 请求更为简便的库。它的项目代码托管在GitHub[1]上,并且支持最新的 Python3 版本。

与requests 库类似,httpx 提供了易用的 API 进行 HTTP 通信,但它是建立在异步 I/O(asyncio)之上,针对现代网络编程提供了更强大的支持,如 HTTP/2、连接池等高级功能。对于需要在 Python 应用中执行 HTTP 请求的开发者来说,httpx 能够提供更高效的性能和更丰富的特性。

如果把 requests 比作是一艘稳定的货轮,那么 httpx 无疑就是一艘配备了最新动力系统的快艇。比如:httpx 支持 HTTP/2 协议,这允许多个请求在同一连接上并发执行,从而显著提高了通信效率。此外,它还内置了对异步请求的支持,这意味着在处理大量请求或高并发的情况时,httpx 表现更为出色。

安装 httpx

安装 httpx 非常简单,通过 pip 即可一键安装:

pip install httpx

基本用法

httpx 的使用方式和 requests 类似,对于初学者来说,从 requests 迁移到 httpx 是一件轻松的事情。

import httpx

# 发送 GET 请求 
response = httpx.get('https://www.example.com')
print(response)

# 发送 POST 请求 
response = httpx.post('https://www.example.com/post', data={'key': 'value'})
print(response)

这些示例代码展示了如何使用 httpx 发送基本的 GET 和POST 请求。

当涉及到请求体和参数时,httpx 同样优雅灵活:

# 上传文件
files = {'file': open('report.xls', 'rb')}
response = httpx.post('https://httpbin.org/post', files=files)

同时,使用 httpx 处理 JSON 数据简直不要太 easy!

# 发送json数据
response = httpx.post('https://httpbin.org/post', json={'message': 'Hello, World!'})

异步请求

httpx 最大的特色之一就是内置了对异步请求的支持。让我们来看看如何使用 async 和 await 关键字来发起异步请求:

import httpx
import asyncio

async def get_async_data(url):
    async with httpx.AsyncClient() as client:
        return await client.get(url)

# 运行异步函数 
asyncio.run(get_async_data('https://www.example.com'))

在这个例子中,我们创建了一个异步函数 get_async_data,它使用了 httpx 的 AsyncClient 来执行异步的 GET 请求。这就允许你同时发起多个网络请求,它们将在单个或多个事件循环中并行运行。

HTTP/2 支持

httpx 对 HTTP/2 的支持允许更高效的网络请求,减少了延迟并提高了吞吐量。启用 HTTP/2 非常简单:

import httpx

# HTTP/2 会话 
with httpx.Client(http2=True) as client:
    response = client.get('https://www.example.com')
    print(response.http_version)  # 输出 'HTTP/2'

开启 HTTP/2 特性只需在 httpx.Client 中设置 http2=True

扩展说明

httpx 还有许多其他高级功能等待探索,比如自定义中间件、事件钩子以及请求重试等等。但是由于篇幅限制,我们这里无法详细介绍每一项特性。建议有兴趣的读者可以访问 httpx 的官方文档[2]来深入了解。

实践

现在,来一次小练习:

  • 使用 httpx 编写一个函数,连接到你最喜欢的网站,获取内容,并打印出 HTTP 响应码和头信息。

  • 修改上面的函数,使其异步执行,并尝试同时请求多个不同的 URL。

  • 尝试开启 HTTP/2 特征,并观察它与 HTTP/1.1 相比有哪些不同之处。

练习  1: 获取网站内容

import httpx

def fetch_site(url):
    with httpx.Client() as client:
        response = client.get(url)
        print('Status Code:', response.status_code)
        print('Headers:', response.headers)

fetch_site('https://www.example.com')

运行此代码,你将看到指定网站的状态码和响应头部信息。

练习  2: 异步获取多个网站内容

import asyncio

async def fetch_site_async(url):
    async with httpx.AsyncClient() as client:
        response = await client.get(url)
        print('URL:', url)
        print('Status Code:', response.status_code)
        print('Headers:', response.headers)

async def main():
    urls = ['https://www.example.com', 'https://www.python.org', 'https://www.github.com']
    tasks = [fetch_site_async(url) for url in urls]
    await asyncio.gather(*tasks)

asyncio.run(main())

运行此代码,你将以异步的方式分别访问多个网站,并同时打印出每一个网站的 HTTP 响应码和头信息。

练习  3: 开启 HTTP/2 特性

修改“练习  1”的 fetch_site 函数,通过开启 HTTP/2 来请求网站:

def fetch_site_http2(url):
    with httpx.Client(http2=True) as client:
        response = client.get(url)
        print('HTTP Version:', response.http_version)

fetch_site_http2('https://www.example.com')

观察输出的 HTTP Version 值,以了解网站是否支持 HTTP/2。

总结

在这篇教程中,我们探讨了 httpx —— 一款现代的、功能丰富且支持异步请求的 Python HTTP 客户端库。就像我们之前比喻的,它如同是装备了最新技术的跑车,在处理现代 Web 编程的挑战时表现卓越,无论是连接的持久化、异步支持,还是 HTTP/2 协议的利用,它都有着强大的功能和明显的优势。

httpx 的出现并不是去替代 requests,而是为了满足日益增长的网络编程需求,提供了更多的选择和更好的工具。无论是作为一名经验丰富的 Python 开发者,还是一个刚刚踏入这个领域的新手,拥抱 httpx,体验上一代 HTTP 客户端库无法比拟的速度和效率,相信会让你的编程之旅更加畅快。

但正如任何技术选型一样,选择合适的工具需根据实际的项目需求。你可能还是要根据自己团队的适应度、项目的特点以及维护的便利性来做出决策。总之,httpx 无疑是 Python 生态中一个闪耀的新星,值得每一位 Python 开发者的尝试和探索。

好了,教程到此结束。希望你既能享受学习的过程,也能在实践中大放异彩!

参考资料

[1]Httpx 项目: https://github.com/encode/httpx 

[2]官方文档: https://www.python-httpx.org/ 

以上就是Python Httpx库实现超跑式网络请求用法实例的详细内容,更多关于Python Httpx库网络请求的资料请关注脚本之家其它相关文章!

相关文章

  • 用Pygal绘制直方图代码示例

    用Pygal绘制直方图代码示例

    这篇文章主要介绍了用Pygal绘制直方图代码示例,具有一定借鉴价值,需要的朋友可以了解下。
    2017-12-12
  • Python中日期和时间的互相转换操作方法

    Python中日期和时间的互相转换操作方法

    Python的datetime模块提供了一套强大而灵活的工具,使我们能够轻松地在不同的时间表示形式间相互转换,并进行复杂的时间计算,本文通过一个实用的例子向大家展示如何在Python中高效地进行这些操作,感兴趣的朋友一起看看吧
    2024-05-05
  • python实现beta分布概率密度函数的方法

    python实现beta分布概率密度函数的方法

    今天小编就为大家分享一篇python实现beta分布概率密度函数的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-07-07
  • selenium+python实现自动化登录的方法

    selenium+python实现自动化登录的方法

    这篇文章主要介绍了selenium+python实现自动化登录的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09
  • pip install python-Levenshtein失败的解决

    pip install python-Levenshtein失败的解决

    这篇文章主要介绍了pip install python-Levenshtein失败的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • python求定积分之quad函数详解

    python求定积分之quad函数详解

    这篇文章主要介绍了python求定积分之quad函数详解,SciPy下实现求函数的积分的函数的基本使用,积分,高等数学里有大量的讲述,基本意思就是求曲线下面积之和,需要的朋友可以参考下
    2023-08-08
  • Python数据列表中的空补0的问题解决

    Python数据列表中的空补0的问题解决

    在Python中,如果你有一个包含空值的数据列表,你可以使用列表推导式或循环将这些空值替换为0,本文就来介绍一下如何解决,感兴趣的可以了解一下
    2024-03-03
  • python如何获取列表中每个元素的下标位置

    python如何获取列表中每个元素的下标位置

    这篇文章主要介绍了python如何获取列表中每个元素的下标位置,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-07-07
  • python通过zlib实现压缩与解压字符串的方法

    python通过zlib实现压缩与解压字符串的方法

    这篇文章主要介绍了python通过zlib实现压缩与解压字符串的方法,较为详细的介绍了zlib的用法及使用zlib.compressobj和zlib.decompressobj对文件进行压缩解压的方法,需要的朋友可以参考下
    2014-11-11
  • Django框架模板用法入门教程

    Django框架模板用法入门教程

    这篇文章主要介绍了Django框架模板用法,结合简单入门实例形式分析了Django框架模板标签、过滤器、模板继承等概念与使用技巧,需要的朋友可以参考下
    2019-11-11

最新评论