我試圖使用python再從中提取一個文件的一些字符串,然後使用MD5ing東西 此字符串,如:散列非ASCII Python字符串
#MD5er.py
salt = extract_salt(file_foo)
print 'salt: %s' % salt
from md5 import md5
print 'hash: %s' % md5(salt).hexdigest()
$蟒蛇MD5er
salt: \0001\072\206\277\354\107\134\061\361\076\150\047\010\124\200\315\100
hash: ce24166858853dfb12a86d7d602b0638
但是,像這樣使用iPython:
In [40]: salt = '\0001\072\206\277\354\107\134\061\361\076\150\047\010\124\200\315\100'
In [41]: salt
Out[41]: "\x001:\x86\xbf\xecG\\1\xf1>h'\x08T\x80\[email protected]"
In [42]: print salt
1:���G\1�>hT��@
In [43]: from md5 import md5
In [44]: md5(salt).hexdigest()
Out[44]: 'ebae47a953591f7448ff7079837fb534'
任何線索爲什麼MD5在2種情況下有所不同? 以及爲什麼在ipython中,當我輸入變量名時,它以與原始字符串不同的格式顯示,而print()輸出是第三種格式!
提示:
In [53]: import sys
In [54]: sys.getdefaultencoding()
Out[54]: 'ascii'
在文件中實際反斜線? –