2、chardet

字符串编码一直是令人非常头疼的问题,尤其是我们在处理一些不规范的第三方网页的时候。虽然Python提供了Unicode表示的strbytes两种数据类型,并且可以通过encode()decode()方法转换,但是,在不知道编码的情况下,对bytesdecode()不好做。

对于未知编码的bytes,要把它转换成str,需要先“猜测”编码。猜测的方式是先收集各种编码的特征字符,根据特征字符判断,就能有很大概率“猜对”。

当然,我们肯定不能从头自己写这个检测编码的功能,这样做费时费力。chardet这个第三方库正好就派上了用场。用它来检测编码,简单易用。

安装

pip install chardet

使用

encoding:编码

confidence:可信度,也就是正确的概率

language:语言种类

import chardet

result = chardet.detect(b'Hello World!')

print(result)

'''
{'encoding': 'ascii', 'confidence': 1.0, 'language': ''}
'''

例子

import chardet

b = '离离原上草,一岁一枯荣'.encode('gbk')
result = chardet.detect(b)

print(result)

'''
{'encoding': 'GB2312', 'confidence': 0.7407407407407407, 'language': 'Chinese'}
'''