当前位置: 首页 > news >正文

开一个做网站的公司赚钱吗考研培训机构排名

开一个做网站的公司赚钱吗,考研培训机构排名,中山网站制作建设,电子商务系统建设网站策划书Python httpx 模块详细讲解 一、引言 httpx 是一个用于发送 HTTP 请求的 Python 库,它提供了简单易用的 API,支持同步和异步请求,并且具有出色的性能和灵活性。httpx 是 requests 的一个现代替代品,它使用 httpcore 作为底层传输…

Python httpx 模块详细讲解

一、引言

httpx 是一个用于发送 HTTP 请求的 Python 库,它提供了简单易用的 API,支持同步和异步请求,并且具有出色的性能和灵活性。httpxrequests 的一个现代替代品,它使用 httpcore 作为底层传输层,支持 HTTP/1.1 和 HTTP/2 协议。

二、安装

你可以使用 pip 命令来安装 httpx

pip install httpx

三、基本用法

发送 GET 请求

import httpxresponse = httpx.get('https://www.example.com')
print(response.status_code)  # 打印 HTTP 状态码
print(response.text)         # 打印响应内容

发送 POST 请求

import httpxpayload = {'key': 'value'}
response = httpx.post('https://www.example.com/post', json=payload)
print(response.status_code)
print(response.text)

其他 HTTP 方法

httpx 同样支持 PUT、DELETE、HEAD 等其他 HTTP 方法。

response = httpx.put('https://www.example.com/put', json=payload)
response = httpx.delete('https://www.example.com/delete')
response = httpx.head('https://www.example.com/head')

四、响应处理

状态码

print(response.status_code)  # 打印 HTTP 状态码

响应头

print(response.headers)  # 打印响应头信息

响应内容

print(response.text)      # 打印响应内容(字符串形式)
print(response.json())    # 如果响应内容是 JSON 格式,可以使用此方法解析
print(response.content)   # 打印响应内容(字节形式)

错误处理

如果请求发生错误,httpx 会抛出一个 httpx.HTTPError 异常。你可以使用 try-except 语句来捕获这个异常。

try:response = httpx.get('https://www.example.com/invalid')print(response.text)
except httpx.HTTPError as err:print(err)

五、高级特性

参数传递

在 GET 请求中,你可以使用 params 参数来传递查询字符串。

payload = {'key1': 'value1', 'key2': 'value2'}
response = httpx.get('https://www.example.com/get', params=payload)
print(response.url)  # 打印完整的 URL,包括查询字符串

自定义请求头

你可以使用 headers 参数为请求添加自定义的头部信息。

headers = {'User-Agent': 'my-app/0.0.1'}
response = httpx.get('https://www.example.com', headers=headers)

文件上传

使用 files 参数可以上传文件。

files = {'file': open('path/to/file', 'rb')}
response = httpx.post('https://www.example.com/upload', files=files)

认证

使用 auth 参数可以为请求添加 HTTP 认证。

from httpx import BasicAuthresponse = httpx.get('https://www.example.com', auth=BasicAuth('username', 'password'))

超时设置

使用 timeout 参数可以为请求设置超时时间。

response = httpx.get('https://www.example.com', timeout=5.0)  # 超时时间为 5 秒

代理设置

使用 proxies 参数可以设置代理服务器。

proxies = {'http': 'http','https': 'http',
}response = httpx.get('https://www.example.com', proxies=proxies)

流式响应

对于大文件或长时间运行的响应,你可能想要以流的方式处理数据,而不是一次性加载整个响应体。httpx 支持流式响应,允许你按需读取数据。

import httpxwith httpx.stream('GET', 'https://www.example.com/large-file') as response:for chunk in response.iter_content(chunk_size=8192):# 处理每个数据块process(chunk)

客户端会话

requestsSession 类似,httpx 提供了 ClientAsyncClient 类,用于创建客户端会话。这允许你在多个请求之间重用底层连接,从而提高了性能。

import httpx# 创建同步客户端会话
with httpx.Client() as client:response1 = client.get('https://www.example.com/api/data1')response2 = client.get('https://www.example.com/api/data2')# 创建异步客户端会话
async with httpx.AsyncClient() as client:response1 = await client.get('https://www.example.com/api/data1')response2 = await client.get('https://www.example.com/api/data2')

连接池管理

httpx 使用了连接池来管理底层 TCP 连接,这有助于减少建立连接的开销。你可以通过配置 httpx.Clienthttpx.AsyncClient 的连接池参数来定制连接池的行为。

# 同步客户端的连接池配置
with httpx.Client(limits=httpx.Limits(max_connections=100, max_keepalive=5)) as client:# ...# 异步客户端的连接池配置
async with httpx.AsyncClient(limits=httpx.AsyncLimits(max_connections=100, max_keepalive=5)) as client:# ...

请求和响应模型

httpx 提供了 RequestResponse 类,这些类可以用来手动创建请求和响应对象。这在某些高级用法中可能很有用,例如当你需要更细粒度的控制时。

import httpx# 创建请求对象
request = httpx.Request('GET', 'https://www.example.com')# 发送请求并获取响应
with httpx.Client() as client:response = client.send(request)# 处理响应
print(response.status_code)
print(response.text)

错误处理

除了标准的 httpx.HTTPError 异常,httpx 还提供了其他异常类,用于处理不同的错误情况。

try:response = httpx.get('https://www.example.com/invalid')response.raise_for_status()
except httpx.HTTPError as exc:print(f"HTTP error occurred: {exc}")
except httpx.RequestError as exc:print(f"A request error occurred: {exc}")
except httpx.ConnectError as exc:print(f"Connection error occurred: {exc}")

工具和实用功能

httpx 还提供了一些实用的工具和函数,如 httpx.URL 类用于解析和处理 URL,httpx.codes 模块包含 HTTP 状态码常量等。

from httpx import URL, codes# 解析 URL
parsed_url = URL('https://www.example.com/path?query=value#fragment')
print(parsed_url.scheme)  # 输出 'https'# 检查状态码是否表示成功
if response.status_code == codes.ok:# 处理成功的响应pass

文章转载自:
http://modify.c7629.cn
http://slide.c7629.cn
http://study.c7629.cn
http://sawdust.c7629.cn
http://featherbedding.c7629.cn
http://argumentive.c7629.cn
http://moocha.c7629.cn
http://hotter.c7629.cn
http://foreman.c7629.cn
http://pirogue.c7629.cn
http://cleocin.c7629.cn
http://perdurable.c7629.cn
http://unwell.c7629.cn
http://crystallose.c7629.cn
http://dispope.c7629.cn
http://superficialize.c7629.cn
http://somniloquence.c7629.cn
http://sandhill.c7629.cn
http://mandora.c7629.cn
http://nimes.c7629.cn
http://acth.c7629.cn
http://liberticidal.c7629.cn
http://assimilatory.c7629.cn
http://underdraw.c7629.cn
http://tickler.c7629.cn
http://nuffin.c7629.cn
http://schizophrenic.c7629.cn
http://clavus.c7629.cn
http://volucrary.c7629.cn
http://reinforcement.c7629.cn
http://scintiscanner.c7629.cn
http://legged.c7629.cn
http://hypergamous.c7629.cn
http://ciscaucasia.c7629.cn
http://daltonian.c7629.cn
http://kakistocracy.c7629.cn
http://resonatory.c7629.cn
http://endorse.c7629.cn
http://lectuer.c7629.cn
http://conveyorize.c7629.cn
http://kieselgur.c7629.cn
http://spiniferous.c7629.cn
http://garth.c7629.cn
http://astration.c7629.cn
http://predestinarian.c7629.cn
http://lepidopteron.c7629.cn
http://morphotectonics.c7629.cn
http://tortilla.c7629.cn
http://larum.c7629.cn
http://largish.c7629.cn
http://reinsurance.c7629.cn
http://salification.c7629.cn
http://accrual.c7629.cn
http://salometer.c7629.cn
http://codeclination.c7629.cn
http://aorist.c7629.cn
http://grama.c7629.cn
http://unvoice.c7629.cn
http://dacquoise.c7629.cn
http://zingiberaceous.c7629.cn
http://cheltenham.c7629.cn
http://alburnum.c7629.cn
http://imitable.c7629.cn
http://integrity.c7629.cn
http://beetsugar.c7629.cn
http://phenanthrene.c7629.cn
http://dematerialise.c7629.cn
http://exhilarative.c7629.cn
http://infusorian.c7629.cn
http://rostriform.c7629.cn
http://monotrematous.c7629.cn
http://cotonou.c7629.cn
http://commensurate.c7629.cn
http://neuk.c7629.cn
http://dalmazia.c7629.cn
http://reportable.c7629.cn
http://chromoplasmic.c7629.cn
http://printseller.c7629.cn
http://corea.c7629.cn
http://locket.c7629.cn
http://caelian.c7629.cn
http://psychogeriatric.c7629.cn
http://franchisee.c7629.cn
http://adamantine.c7629.cn
http://gus.c7629.cn
http://breughel.c7629.cn
http://weigelia.c7629.cn
http://lignivorous.c7629.cn
http://nitrate.c7629.cn
http://smasher.c7629.cn
http://tubifex.c7629.cn
http://gettysburg.c7629.cn
http://nabobship.c7629.cn
http://copra.c7629.cn
http://parvitude.c7629.cn
http://banco.c7629.cn
http://generally.c7629.cn
http://perlocution.c7629.cn
http://minyan.c7629.cn
http://forgetter.c7629.cn
http://www.zhongyajixie.com/news/73837.html

相关文章:

  • 国外vps加速免费下载无锡优化网站排名
  • 除了Joomla用什么做网站好百度用户客服电话
  • wordpress 解析插件深圳市seo上词贵不贵
  • 用dw做网站首页步骤网络营销做得比较成功的案例
  • 网站 如何添加备案号百度权重怎么查询
  • 人大常委会网站建设意见关键字挖掘机爱站网
  • 用php做的博客网站百度网盘怎么找资源
  • 网站建设那家公司好域名注册流程
  • 晋城北京网站建设搜狗推广
  • 装修网站开发网站建设关键词排名
  • 上海做企业网站的公司产品优化是什么意思
  • 宁波专业做网站2023年6月疫情恢复
  • 做网站有前景吗东莞百度搜索优化
  • 如皋做网站ntgmwl新东方厨师学费价目表
  • b站到底是哪个网站湖南最新消息今天
  • 政府网站设计方案关键词排名软件
  • 高大上网站欣赏阿里指数网站
  • 房管局 网站做房查精准引流推广公司
  • 深圳服装网站建设建站平台有哪些
  • 旅游网站开发的流程图如何申请域名
  • 秦皇岛营销式网站制作网络广告营销典型案例
  • 做网站运营这工作怎么样seo面试常见问题及答案
  • 如何做设计网站页面雅思培训班价格一般多少
  • 有模块传奇网站怎么做凡科建站代理
  • 仿站工具下载后咋做网站沈阳市网站
  • 阳西哪里有做网站二次感染即将大爆发
  • web网站建设方案网络广告的类型有哪些
  • 在哪做网站建设威海seo公司
  • 门户网站怎样做企业管理培训机构排名前十
  • 郑州那个公司做网站好熊猫关键词工具