我的问题是,我有一个用不同索引表编码的东西(类似base64):
0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz+/
而不是
ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/
所以当我使用base64.b64decode()
时,它给了我一个错误的结果。
在转换期间是否有方法设置此表(可能作为参数)?
或者我应该“转换”错误的base64字符串,我的意思是将0替换为A,1替换为B,等等。。。比使用base64decode?如果是这样的话,最好的快速解决方法是什么?
update1:我使用这个,它可以工作,但看起来有点慢,而且不专业。:)
def correctbase64(str):
dicta = [ ['0','A'], ['1','B'], ['2','C'], ['3','D'], ['4','E'], ['5','F'], ['6','G'], ['7','H'], ['8','I'], ['9','J'], ['A','K'], ['B','L'], ['C','M'], ['D','N'], ['E','O'], ['F','P'], ['G','Q'], ['H','R'], ['I','S'], ['J','T'], ['K','U'], ['L','V'], ['M','W'], ['N','X'], ['O','Y'], ['P','Z'], ['Q','a'], ['R','b'], ['S','c'], ['T','d'], ['U','e'], ['V','f'], ['W','g'], ['X','h'], ['Y','i'], ['Z','j'], ['a','k'], ['b','l'], ['c','m'], ['d','n'], ['e','o'], ['f','p'], ['g','q'], ['h','r'], ['i','s'], ['j','t'], ['k','u'], ['l','v'], ['m','w'], ['n','x'], ['o','y'], ['p','z'], ['q','0'], ['r','1'], ['s','2'], ['t','3'], ['u','4'], ['v','5'], ['w','6'], ['x','7'], ['y','8'], ['z','9'] ]
l = list(str)
for i in range(len(l)):
for c in dicta:
if l[i] == c[0]:
l[i] = c[1]
break
return "".join(l)
类似的东西应该可以工作(警告:未经测试的代码;可能充满错误):
不可能让标准的
base64
函数(或它们调用的binascii
中的低级函数)使用自定义表。使用maketrans构建一个翻译表,然后从第一个字母表翻译到第二个字母表。然后base64解码。
您可以使用^{} 和^{} :
相关问题 更多 >
编程相关推荐