Niquests 3.14.0版本发布:增强异步HTTP客户端功能
Niquests是一个基于Python的HTTP客户端库,它提供了同步和异步两种请求方式。该项目旨在为开发者提供简单易用且功能强大的HTTP请求工具,支持多种高级特性如连接池、超时控制、自动解压缩等。最新发布的3.14.0版本在异步功能方面做了重要增强,并修复了一些关键问题。
新增功能亮点
异步请求的顶层API
3.14.0版本引入了与同步请求相对应的异步顶层API,包括aget、apost、aput等方法。这些方法为开发者提供了更加直观和便捷的异步请求方式,无需显式创建会话实例即可发起异步HTTP请求。
例如,现在可以直接使用:
response = await niquests.aget('https://example.com')
全局超时配置
新版本允许在创建Session或AsyncSession时设置全局超时参数。这一改进简化了超时配置,开发者不再需要为每个请求单独设置超时时间。
# 同步会话设置10秒全局超时
session = niquests.Session(timeout=10)
# 异步会话设置5秒全局超时
async_session = niquests.AsyncSession(timeout=5)
原始内容迭代支持
新增的iter_raw方法允许开发者获取未经解压缩处理的原始响应内容。这在处理大型文件或需要直接操作原始数据流的场景中特别有用。
# 同步方式
response = session.get('https://example.com/large-file')
for chunk in response.iter_raw():
process_raw_data(chunk)
# 异步方式
async_response = await async_session.get('https://example.com/large-file')
async for chunk in async_response.iter_raw():
await process_raw_data_async(chunk)
调试信息增强
为HTTP适配器添加了__repr__方法,使得调试时能够获取更多有用的信息,帮助开发者更快定位问题。
重要问题修复
-
修复了
AsyncResponse.close()方法中未正确等待协程的问题,确保资源能够被正确释放。 -
解决了在异步模式下尝试调用不可等待的urllib3原始响应对象的
close方法的问题,提高了异步操作的稳定性。
技术价值分析
3.14.0版本的发布标志着Niquests在异步HTTP客户端领域的进一步成熟。新增的异步顶层API降低了异步编程的门槛,使开发者能够更自然地编写异步HTTP请求代码。全局超时配置的引入则体现了对开发者体验的重视,减少了重复配置的工作量。
原始内容迭代功能的加入扩展了库的应用场景,特别是在处理大文件或需要精细控制数据流的场景中。这些改进共同提升了Niquests作为现代Python HTTP客户端库的竞争力。
对于正在使用或考虑使用Niquests的开发者来说,3.14.0版本提供了更完善的异步支持,更简洁的API设计,以及更稳定的运行表现,值得升级体验。
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5-w4a8GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术,结合vLLM推理优化,高效平衡性能与精度,助力智能应用开发Jinja00
jiuwenclawJiuwenClaw 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。Python0215- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
AtomGit城市坐标计划AtomGit 城市坐标计划开启!让开源有坐标,让城市有星火。致力于与城市合伙人共同构建并长期运营一个健康、活跃的本地开发者生态。01
OpenDeepWikiOpenDeepWiki 是 DeepWiki 项目的开源版本,旨在提供一个强大的知识管理和协作平台。该项目主要使用 C# 和 TypeScript 开发,支持模块化设计,易于扩展和定制。C#00