python 的 httpx 包是一个复杂的 web 客户端。当你安装它后,你就可以用它来从网站上获取数据。像往常一样,安装它的最简单方法是使用 pip 工具:
$ python -m pip install httpx --user
要使用它,把它导入到 python 脚本中,然后使用 .get 函数从一个 web 地址获取数据:
import httpx
result = httpx.get(https://httpbin.org/get?hello=world)
result.json()[args]
下面是这个简单脚本的输出:
{'hello': 'world'}
http 响应默认情况下,httpx 不会在非 200 状态下引发错误。
试试这个代码:
result = httpx.get(https://httpbin.org/status/404)
result
结果是:
可以明确地返回一个响应。添加这个异常处理:
try:
result.raise_for_status()
except exception as exc:
print(woops, exc)
下面是结果:
woops client error '404 not found' for url 'https://httpbin.org/status/404'
for more information check: https://httpstatuses.com/404
自定义客户端除了最简单的脚本之外,使用一个自定义的客户端是有意义的。除了不错的性能改进,比如连接池,这也是一个配置客户端的好地方。
例如, 你可以设置一个自定义的基本 url:
client = httpx.client(base_url=https://httpbin.org)
result = client.get(/get?source=custom-client)
result.json()[args]
输出示例:
{'source': 'custom-client'}
这对用客户端与一个特定的服务器对话的典型场景很有用。例如,使用 base_url 和 auth,你可以为认证的客户端建立一个漂亮的抽象:
client = httpx.client(
base_url=https://httpbin.org,
auth=(good_person, secret_password),
)
result = client.get(/basic-auth/good_person/secret_password)
result.json()
输出:
{'authenticated': true, 'user': 'good_person'}
你可以用它来做一件更棒的事情,就是在顶层的 “主” 函数中构建客户端,然后把它传递给其他函数。这可以让其他函数使用客户端,并让它们与连接到本地 wsgi 应用的客户端进行单元测试。
def get_user_name(client):
result = client.get(/basic-auth/good_person/secret_password)
return result.json()[user]
get_user_name(client)
'good_person'
def application(environ, start_response):
start_response('200 ok', [('content-type', 'application/json')])
return [b'{user: pretty_good_person}']
fake_client = httpx.client(app=application, base_url=https://fake-server)
get_user_name(fake_client)
输出:
'pretty_good_person'
尝试 httpx请访问 python-httpx.org 了解更多信息、文档和教程。我发现它是一个与 http 交互的优秀而灵活的模块。试一试,看看它能为你做什么。
以上就是介绍和使用 python 的 httpx web 客户端的详细内容。