首页 > 编程问答 >在 HTTPX 或请求中传递特殊字符而不进行编码

在 HTTPX 或请求中传递特殊字符而不进行编码

时间:2024-08-08 04:56:43浏览次数:10  
标签:python python-requests httpx wunderground

我使用的 API (wunderground) 要求日期格式为“2001-01-01 10:32:35”,(他们声称)应该将 URL 转义为“2000-01-01+10%” 3A32%3A35"。 HTTPX 和 Requests 都做得很好,只是它们将 + 编码为 %2B,这是 API 不期望的。如何防止请求或 HTTPX 对 + 进行编码?

示例代码:


auth = {
        'ID': station,
        'PASSWORD': stationKey,
        'dateutc': 2024-08-07+19%3A58%3A43,
        'tempf': 65.1,
        'action': "updateraw"
           }

            
r = httpx.get('https://weatherstation.wunderground.com/weatherstation/updateweatherstation.php', params=auth)

OR

r = requests.get('https://weatherstation.wunderground.com/weatherstation/updateweatherstation.php', params=auth)

print(r.url)

输出:

https://weatherstation.wunderground.com/weatherstation/updateweatherstation.php?ID=XXXX&PASSWORD=XXXXX&dateutc=2024-08-07%2B20%253A08%253A41&tempf=65.1&action=updateraw

是对的,HTTPX 和 Requests 会自动对 URL 中的特殊字符进行编码,包括加号 ( + )。尽管根据标准,加号在 URL 中表示空格,并且应该被编码为 %2B ,但看起来 Wunderground 的 API 在这种情况下需要非标准的行为。

有两个选择来解决这个问题:

1. 手动构建 URL 参数字符串:

可以避免使用 params 参数,而是手动构建查询字符串,并完全按照 API 所需的方式对日期时间进行格式化。

import httpx

auth = {
    'ID': station,
    'PASSWORD': stationKey,
    'tempf': 65.1,
    'action': "updateraw"
}

dateutc = '2024-08-07+19%3A58%3A43' 

url = f'https://weatherstation.wunderground.com/weatherstation/updateweatherstation.php?ID={auth["ID"]}&PASSWORD={auth["PASSWORD"]}&dateutc={dateutc}&tempf={auth["tempf"]}&action={auth["action"]}'

r = httpx.get(url)

print(r.url)

2. 使用 urllib.parse.quote 对日期时间进行编码,并指定 safe 参数:

可以使用 urllib.parse.quote 函数对日期时间字符串进行编码,并使用 safe 参数指定哪些字符不应被编码。

import httpx
from urllib.parse import quote

auth = {
    'ID': station,
    'PASSWORD': stationKey,
    'dateutc': quote('2024-08-07+19:58:43', safe='+:'),  # 保留 + 和 : 不编码
    'tempf': 65.1,
    'action': "updateraw"
}

r = httpx.get('https://weatherstation.wunderground.com/weatherstation/updateweatherstation.php', params=auth)

print(r.url)

这两种方法都可以解决问题,并生成 Wunderground API 所需的 URL 格式。

请注意,依赖于非标准 URL 编码的 API 可能会导致问题。 如果可能,最好联系 Wunderground 并询问他们是否可以更新其 API 以遵循标准做法。

标签:python,python-requests,httpx,wunderground
From: 78845599

相关文章

  • 为什么 Python NewType 与 isinstance 和 type 不兼容?
    这似乎不起作用:fromtypingimportNewTypeMyStr=NewType("MyStr",str)x=MyStr("HelloWorld")isinstance(x,MyStr)我什至没有得到False,但是TypeError:isinstance()arg2mustbeatypeortupleoftypes因为MyStr是一个函数......
  • Python & Selenium 4 & Edge 浏览器 |加载个人浏览器配置文件(包括cookie)
    使用Selenium4,我尝试加载我的个人浏览器配置文件(包括cookie),以便它可以加载到我之前登录过的网站。我正在使用边缘浏览器。在测试我的代码片段时,它似乎没有加载我的浏览器配置文件,而是创建一个新的(配置文件1)。我已确保配置文件的路径是正确的。我的代码片段:edge_opt......
  • 如何在通用 Python 类中输入 __eq__ ?
    当我定义带有泛型类型参数的类型时(例如K/V映射的键和值),我似乎无法编写合适的isinstance检查来实现__eq__:fromcollectionsimportOrderedDictfromcollections.abcimportMutableMappingfromtypingimportTypeVarK=TypeVar("K")......
  • 无法使用 devstack 安装 openstack 因为 python 版本
    我正在使用默认的python3.8.10运行./stack.sh,我收到此错误,因为我需要3.9或更高版本3.8msg错误但是当我将默认版本更改为3.9时,我收到错误没有找到模块“apt_pkg”3.9msgerror我一直在em之间来回跳动,但错误仍然存​​在(我也每次都会检查版本)......
  • Python @overload 使用联合类型会导致函数签名重叠错误
    我想编写以下重载的Python函数:fromtypingimportAny,TypeVar,overload_T1=TypeVar('_T1')_T2=TypeVar('_T2')_T3=TypeVar('_T3')@overloaddefparse_as(ty:type[_T1]|type[_T2],s:bytes)->_T1|_T2:...@overload......
  • python joblib.load 发生错误:协议 0 中的持久 ID 必须是 ASCII 字符串 在 GCP 云运行
    总体而言:我尝试使用Cloudbuild和Cloudrun构建BERT模型。我将模型(参数)和元数据(标签)保存在GCPCloudStorage中。但是,我遇到了通过joblib.load()加载metadata.bin文件的错误。我的metadata.bin文件包含UTF-8字符,但joblib.load需要ASCII字符。在......
  • Python + Svelte,如何使用本地文件系统
    总结一下,我有一个用python编写的应用程序。它在输入时需要一堆视频文件。使用一些魔法并生成合并的视频文件输出。我没有找到一个好的GUI解决方案(tkinter,QT,TUI等),所以我选择Svelte框架。但是出现了一个问题,我如何使用本地文件系统。在GUI(svelte)上,我必须上......
  • 如何在Python中绘制伪球面
    目标是使用meshgrid和numpy库生成伪球体的三维图形,但我使用下面的代码生成的图形不完整u=np.linspace(0,np.pi,50)v=np.linspace(0,2*np.pi,100)x,y=np.meshgrid(u,v)X=np.arccos(x)*np.cos(y)Y=np.arccos(x)*np.sin(y)Z=x-np.tan(x)fig=plt.f......
  • 18:Python集合属性
    #Python3集合#集合(set)是一个无序的不重复元素序列。#集合中的元素不会重复,并且可以进行交集、并集、差集等常见的集合操作。#集合中元素必须是不可变类型,也就说里面不能是列表和字典#可以使用大括号{}创建集合,元素之间用逗号,分隔,或者也可以使用set()函数创建集合。s......
  • Python爬虫案例与实战:爬取源代码练习评测结果
    Python爬虫案例与实战:爬取源代码练习评测结果本章案例将介绍用Python编写程序实现简单网站的模拟登录,然后保持登录后的网页会话,并在会话中模拟网页表单提交,之后使用Requests库的高级特性爬取提交之后的返回结果。在HTTP网页中,如登录、提交和上传等操作一般通过向网页发送......