問題:
比對算法測試腳本在python2.7上跑的沒問題,在python3上報錯,將base64轉碼之后的串打印出來發現,2.7版本和3是不一樣的;2.7就是字符串類型的,但是3是bytes類型的,形如:b'ivaefef....’
做如下修改:
bs64_face_image = img_to_base64(face_img).decode('gbk') bs64_id_image = img_to_base64(id_img).decode('gbk')
然后腳本就正常了;
以下為百度參考文章,轉載過來:
Python 3最重要的新特性大概要算是對文本和二進制數據作了更為清晰的區分。文本總是Unicode,由str類型表示,二進制數據則由bytes類型表示。Python 3不會以任意隱式的方式混用str和bytes,正是這使得兩者的區分特別清晰。你不能拼接字符串和字節包,也無法在字節包里搜索字符串(反之亦然),也不能將字符串傳入參數為字節包的函數(反之亦然).
python3.0中怎么創建bytes型數據
bytes([1,2,3,4,5,6,7,8,9]) bytes("python", 'ascii') # 字符串,編碼
首先來設置一個原始的字符串,
Python 3.2.3 (default, Apr 11 2012, 07:15:24) [MSC v.1500 32 bit (Intel)] on win32 Type "help", "copyright", "credits" or "license" for more information. >>> website = 'http://www.jb51.net/' >>> type(website) <class 'str'> >>> website 'http://www.jb51.net/' >>>
按utf-8的方式編碼,轉成bytes
>>> website_bytes_utf8 = website.encode(encoding="utf-8") >>> type(website_bytes_utf8) <class 'bytes'> >>> website_bytes_utf8 b'http://www.jb51.net/' >>>
按gb2312的方式編碼,轉成bytes
>>> website_bytes_gb2312 = website.encode(encoding="gb2312") >>> type(website_bytes_gb2312) <class 'bytes'> >>> website_bytes_gb2312 b'http://www.jb51.net/' >>>
解碼成string,默認不填
>>> website_string = website_bytes_utf8.decode() >>> type(website_string) <class 'str'> >>> website_string 'http://www.jb51.net/' >>> >>>
解碼成string,使用gb2312的方式
>>> website_string_gb2312 = website_bytes_gb2312.decode("gb2312") >>> type(website_string_gb2312) <class 'str'> >>> website_string_gb2312 'http://www.jb51.net/' >>>