;不能由parse_qsl()处理。有什么办法让它知道;吗?谢谢。
>>> import urllib.parse
>>> urllib.parse.parse_qsl('http://example.com/?q=abc&p=1;2;3')
[('http://example.com/?q', 'abc'), ('p', '1')]发布于 2019-11-11 08:34:24
最好确保您正在处理的URL具有分号URL编码。例如http://example.com/?q=abc&p=1%3B2%3B3
如果由于某种原因不能这样做,您可以这样做:
from urllib.parse import urlparse, unquote_plus
url = "http://example.com/?q=abc&p=1;2;3"
parts = urlparse(url)
qs = parts.query
pairs = [p.split("=", 1) for p in qs.split("&")]
decoded = [(unquote_plus(k), unquote_plus(v)) for (k, v) in pairs]>>> decoded
[('q', 'abc'), ('p', '1;2;3')]上面的代码假设了查询字符串的一些内容。所有的键都有值。如果你想要做更少假设的事情,请看parse_qsl source code。
发布于 2019-11-11 08:41:46
实际上,它确实正确地对待它们(作为分隔符)。您只需告诉它保留空白值:
>>> urllib.parse.parse_qsl('q=abc&p=1;2;3', keep_blank_values=True)
[('q', 'abc'), ('p', '1'), ('2', ''), ('3', '')]请注意,您不应该将整个url传递给parse_qsl,只传递querystring部分。
https://stackoverflow.com/questions/58783696
复制相似问题