遇到需要将emoji表情存入数据库的时候,比如评论内容,微信用户昵称等等,往往不能直接存入数据库,数据库需要转换编码格式
但是这样太麻烦了
有什么简便的方法吗?答案是有的
不管三七二十一把外界获取的字符串先转码再存入数据库,比如
>>> '????'.encode('raw_unicode_escape')
b'\\U0001f638\\U0001f63b\\U0001f480\\U0001f31f'
但是取出来的时候就有点麻烦了 因为数据库会保存为str类型
“b'\\U0001f638\\U0001f63b\\U0001f480\\U0001f31f'” .decode('raw_unicode_escape') 就会报 'str' object has no method decode 的错
解决方案是,转码后再解码为其他格式,目的为去掉b
>>> '????'.encode('raw_unicode_escape').decode()
'\\U0001f638\\U0001f63b\\U0001f480\\U0001f31f'
因此存入数据库就是这么一串字符'\\U0001f638\\U0001f63b\\U0001f480\\U0001f31f'
需要获取的时候再转码为其他格式,目的为加上b
>>> '\\U0001f638\\U0001f63b\\U0001f480\\U0001f31f'.encode()
b'\\U0001f638\\U0001f63b\\U0001f480\\U0001f31f'
如此就可以对这串字符进行解码了
>>> '\\U0001f638\\U0001f63b\\U0001f480\\U0001f31f'.encode().decode('raw_unicode_escape')
'????'
完美!!!!!!!!!!!!!!