将字符串转换为Unicode转义序列

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

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

请注意,该函数应返回原始字符串或对反斜杠进行转义(这样我就可以实际看到转义)。我见过this post,但它与haskell并没有真正的联系。

lanniulan 回答:将字符串转换为Unicode转义序列

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
,
def encode(s):
    ret = []
    for c in s:
        n = ord(c)
        ret.append("\\u{:04x}".format(n))
    return "".join(ret)
#


print(encode("aeiouäöüßéá€æÆΑαΒβΓγ"))
本文链接:https://www.f2er.com/3070257.html

大家都在问