例如我有一个字符串
>>> sample = "Hello World!"
我想做一个可以将 sample
转换为 int 的函数。我知道 chr()
和 ord()
。到目前为止我已经使用过这个:
字符串转整数
>>> res="".join([str(ord(char)) for char in sample])
>>> print(res)
72101108108111328711111410810033
现在问题来了。我如何将 res
转换回 sample
。任何建议将不胜感激。
Note: sample string can also have unicode characters in it
编辑:
nchars=len(sample)
res = sum(ord(sample[byte])<<8*(nchars-byte-1) for byte in range(nchars)) # string to int
print(''.join(chr((res>>8*(nchars-byte-1))&0xFF) for byte in range(nchars))) #int to string
我找到了这个解决方案,但这很慢,有人知道改进这个吗
答案 0 :(得分:1)
我正在保存由“”分隔的数字,因此可以更轻松地返回转换
这很有效,而且很简单:
i = "Hello World"
num = ""
for char in i:
num += str(ord(char))+" "
print(''.join(num.split()))
back = ""
for n in num.split():
back += chr(int(n))
print(back)
输出:
721011081081113287111114108100
Hello World
答案 1 :(得分:0)
sample = "Hello World!"
d1={k:str(ord(v)) for k,v in list(enumerate(sample))}
''.join(d1.values())
'72101108108111328711111410810033'
res1="".join([chr(int(char)) for char in d1.values()])
res1
'Hello World!'
为了避免 which ord(chr) belongs to which chr?
的问题,我们需要像数据结构这样的映射,dict 是最好的存储每个字符串并使用 enumerate
将它们分配给唯一键的方法,这将在飞。
我们的 d1
看起来像这样:
{0: '72',
1: '101',
2: '108',
3: '108',
4: '111',
5: '32',
6: '87',
7: '111',
8: '114',
9: '108',
10: '100',
11: '33'}
然后是将字符串值转换为 int 并对其应用 chr
以转换回字符串的简单部分。
由于 OP
不想使用多个变量或数据结构。
sample = "Hello World!"
l_n=[str(ord(i))+str(ord('@')) for i in list(sample)]
text="".join(l_n)
n_l=[chr(int(i)) for i in text.split('64') if i.isnumeric()]
''.join(n_l)
问题是我们需要知道在哪里应用 char
,所以我在每个字母中添加了一个额外的 @
以便很容易将其转换回来