How can I convert strings like “\u5c0f\u738b\u5b50

2020-04-28 07:11发布

I am now working on a small tool to request and decode a webpage, on which the Chinese characters are stored as string like

\u5c0f\u738b\u5b50\u003a\u6c49\u6cd5\u82f1\u5bf9\u7167 

in the source code, something of unicode. I want to convert it to Chinese characters.

I can make it through this website http://rishida.net/tools/conversion/. But How can I make it using python?

1条回答
姐就是有狂的资本
2楼-- · 2020-04-28 08:04

Those are Unicode codepoints already. They represent Chinese characters, but using escape codes that are easier on the developer:

>>> print u'\u5c0f\u738b\u5b50\u003a\u6c49\u6cd5\u82f1\u5bf9\u7167'
小王子:汉法英对照

You do not have to do anything to convert those; the \uxxxx escape form is simply another way to express the same codepoint. See String Literals:

\uxxxx
Character with 16-bit hex value xxxx (Unicode only)
\Uxxxxxxxx
Character with 32-bit hex value xxxxxxxx (Unicode only)

Python interprets those escape codes when reading the source code to construct the unicode value.

If the source of the data is not from Python source code but from the web, you have JSON data instead, which uses the same escape format:

>>> import json
>>> print json.loads('"\u5c0f\u738b\u5b50\u003a\u6c49\u6cd5\u82f1\u5bf9\u7167"')
小王子:汉法英对照

Note that the value then needs to be part of a larger string, one that at least includes quotes to mark this a string.

Also note that the JSON string escape format differs from Python's when it comes to non-BMP (supplementary) codepoints; JSON treats those like UTF-16 does, by creating a surrogate pair and use two \uxxxx sequences for such a codepoint. In Python you'd use a \Uhhhhhhhh 32-bit hex value.

查看更多
登录 后发表回答