首页 > 解决方案 > 将字符串转换为 unicode 转义序列

问题描述

我想在 python 3 中将字符串转换为 unicode 转义序列,以便以后使用。例如:

string = "Hello, World!\n"
print(string.unicode_escape())
# shoud print \u0048\u0065\u006C\u006C\u006F\u002C\u0020...

请注意,该函数应返回原始字符串或转义反斜杠(因此我可以实际看到转义)。我看过这篇文章,但它并没有真正相关,因为它超越了haskell。

标签: pythonpython-3.xstringunicodeescaping

解决方案


ord()函数返回字符的 Unicode 代码点。只需将其格式化为\u后跟一个 4 位十六进制表示。

def unicode_escape(s):
    return "".join(map(lambda c: rf"\u{ord(c):04x}", s))
print(unicode_escape("Hello, World!\n"))
# prints \u0048\u0065\u006c\u006c\u006f\u002c\u0020\u0057\u006f\u0072\u006c\u0064\u0021\u000a

推荐阅读