我正在尝试解码我的字符串中的十六进制值,所以在最后我有一个“可读”的字符串。
例如:
encoded_string = 'videoplayback%253Fexpire%253D1532566750%2526mime%253Dvideo%25252Fmp4%2526key%253Dyt6%2526mt%253D1532544983%2526fvip%253D5%2526i'
每个十六进制值由一个%符号表示,值的长度可以区分。我尝试的是手动解码字符串:
encoded_string = encoded_string.replace('%253A', '\x25\x3A')
encoded_string = encoded_string.replace('%252F', '\x25\x2F')
encoded_string = encoded_string.replace('%253F', '\x25\x3F')
encoded_string = encoded_string.replace('%253D1532566750', '\x25\x3D\x15\x32\x56\x67\x50')
现在我需要一个能够找到十六进制值并解码它们的函数的帮助。
谢谢你们!
发布于 2018-07-26 05:57:05
工作太多了。
>>> urllib.parse.unquote(urllib.parse.unquote(encoded_string))
'videoplayback?expire=1532566750&mime=video%2Fmp4&key=yt6&mt=1532544983&fvip=5&i'
发布于 2018-07-26 06:03:45
为此,您可以使用正则表达式:
re.sub(
r'%([A-F0-9]{4,14})',
lambda m: str(int(m.groups()[0], 16)),
encoded_string
)
虽然我不确定你是否只想做URL解码?
https://stackoverflow.com/questions/51528213
复制相似问题