我想将字符串转换为python 3中的unicode转义序列,以后可以使用。例如:
string = "Hello, World!\n"
print(string.unicode_escape())
# shoud print \u0048\u0065\u006C\u006C\u006F\u002C\u0020...
请注意,该函数应返回原始字符串或对反斜杠进行转义(这样我就可以实际看到转义)。我见过this post,但它与haskell并没有真正的联系。
答案 0 :(得分:2)
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
答案 1 :(得分:0)
def encode(s):
ret = []
for c in s:
n = ord(c)
ret.append("\\u{:04x}".format(n))
return "".join(ret)
#
print(encode("aeiouäöüßéá€æÆΑαΒβΓγ"))