329

私はPythonの初心者である限り、十分な時間を費やしてきました。
どうすればそのような URL をデコードできますか:

example.com?title=%D0%BF%D1%80%D0%B0%D0%B2%D0%BE%D0%B2%D0%B0%D1%8F+%D0%B7%D0%B0%D1%89%D0%B8%D1%82%D0%B0

Python 2.7のこれに:example.com?title==правовая+защита

url=urllib.unquote(url.encode("utf8"))非常に醜いものを返しています。

まだ解決策はありません。助けていただければ幸いです。

4

4 に答える 4

535

データは URL 引用符でエスケープされた UTF-8 でエンコードされたバイトであるため、パーセントでエンコードされたデータから UTF-8 バイト、さらにテキストへのデコードを透過的に処理する を使用して、 をデコードします。urllib.parse.unquote()

from urllib.parse import unquote

url = unquote(url)

デモ:

>>> from urllib.parse import unquote
>>> url = 'example.com?title=%D0%BF%D1%80%D0%B0%D0%B2%D0%BE%D0%B2%D0%B0%D1%8F+%D0%B7%D0%B0%D1%89%D0%B8%D1%82%D0%B0'
>>> unquote(url)
'example.com?title=правовая+защита'

Python 2 に相当するものは ですurllib.unquote()が、これはバイト文字列を返すため、手動でデコードする必要があります。

from urllib import unquote

url = unquote(url).decode('utf8')
于 2013-05-15T13:19:03.427 に答える
158

Python 3 を使用している場合は、次を使用できます。urllib.parse

url = """example.com?title=%D0%BF%D1%80%D0%B0%D0%B2%D0%BE%D0%B2%D0%B0%D1%8F+%D0%B7%D0%B0%D1%89%D0%B8%D1%82%D0%B0"""

import urllib.parse
urllib.parse.unquote(url)

与えます:

'example.com?title=правовая+защита'
于 2015-09-08T07:42:15.040 に答える
1

HTML では、URL に html エンティティを含めることができます。これもそれらを置き換えます。

#from urllib import unquote #earlier python version
from urllib.request import unquote
from html import unescape
unescape(unquote('https://v.w.xy/p1/p22?userId=xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx&confirmationToken=7uAf%2fxJoxRTFAZdxslCn2uwVR9vV7cYrlHs%2fl9sU%2frix9f9CnVx8uUT%2bu8y1%2fWCs99INKDnfA2ayhGP1ZD0z%2bodXjK9xL5I4gjKR2xp7p8Sckvb04mddf%2fiG75QYiRevgqdMnvd9N5VZp2ksBc83lDg7%2fgxqIwktteSI9RA3Ux9VIiNxx%2fZLe9dZSHxRq9AA'))
于 2021-08-11T11:24:41.370 に答える