Url decode UTF-8 in Python
Become part of the top 3% of the developers by applying to Toptal https://topt.al/25cXVn
--
Music by Eric Matyas
https://www.soundimage.org
Track title: Puzzle Game 3
--
Chapters
00:00 Question
00:40 Accepted answer (Score 606)
01:23 Answer 2 (Score 163)
01:44 Answer 3 (Score 26)
02:19 Answer 4 (Score 2)
02:44 Thank you
--
Full question
https://stackoverflow.com/questions/1656...
Accepted answer links:
[urllib.parse.unquote()]: https://docs.python.org/3/library/urllib...
[urllib.unquote()]: https://docs.python.org/2/library/urllib...
Answer 2 links:
[urllib.parse.unquote]: https://docs.python.org/3/library/urllib...
--
Content licensed under CC BY-SA
https://meta.stackexchange.com/help/lice...
--
Tags
#python #encoding #utf8 #urldecode
#avk47
--
Music by Eric Matyas
https://www.soundimage.org
Track title: Puzzle Game 3
--
Chapters
00:00 Question
00:40 Accepted answer (Score 606)
01:23 Answer 2 (Score 163)
01:44 Answer 3 (Score 26)
02:19 Answer 4 (Score 2)
02:44 Thank you
--
Full question
https://stackoverflow.com/questions/1656...
Accepted answer links:
[urllib.parse.unquote()]: https://docs.python.org/3/library/urllib...
[urllib.unquote()]: https://docs.python.org/2/library/urllib...
Answer 2 links:
[urllib.parse.unquote]: https://docs.python.org/3/library/urllib...
--
Content licensed under CC BY-SA
https://meta.stackexchange.com/help/lice...
--
Tags
#python #encoding #utf8 #urldecode
#avk47
ACCEPTED ANSWER
Score 664
The data is UTF-8 encoded bytes escaped with URL quoting, so you want to decode, with urllib.parse.unquote(), which handles decoding from percent-encoded data to UTF-8 bytes and then to text, transparently:
from urllib.parse import unquote
url = unquote(url)
Demo:
>>> 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=правовая+защита'
The Python 2 equivalent is urllib.unquote(), but this returns a bytestring, so you'd have to decode manually:
from urllib import unquote
url = unquote(url).decode('utf8')
ANSWER 2
Score 176
If you are using Python 3, you can use urllib.parse.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"""
import urllib.parse
urllib.parse.unquote(url)
gives:
'example.com?title=правовая+защита'
ANSWER 3
Score 30
You can achieve an expected result with requests library as well:
import requests
url = "http://www.mywebsite.org/Data%20Set.zip"
print(f"Before: {url}")
print(f"After: {requests.utils.unquote(url)}")
Output:
$ python3 test_url_unquote.py
Before: http://www.mywebsite.org/Data%20Set.zip
After: http://www.mywebsite.org/Data Set.zip
Might be handy if you are already using requests, without using another library for this job.
ANSWER 4
Score 2
In HTML the URLs can contain html entities. This replaces them, too.
#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'))