python chardet简单应用

python的字符串编码识别模块(第三方库):python

 
import chardet
import urllib
 
# 可根据须要,选择不一样的数据
TestData = urllib.urlopen('http://www.baidu.com/').read()
print chardet.detect(TestData)
 
# 运行结果:
# {'confidence': 0.99, 'encoding': 'GB2312'}
运行结果表示有99%的几率认为这段代码是GB2312编码方式。
 
import urllib
from chardet.universaldetector import UniversalDetector
usock = urllib.urlopen('http://www.baidu.com/')
# 建立一个检测对象
detector = UniversalDetector()
for line in usock.readlines():
# 分块进行测试,直到达到阈值
detector.feed(line)
if detector.done: break
# 关闭检测对象
detector.close()
usock.close()
# 输出检测结果
print detector.result
 
# 运行结果:
# {'confidence': 0.99, 'encoding': 'GB2312'}
应用背景,若是要对一个大文件进行编码识别,使用这种高级的方法,能够只读一部,去判别编码方式从而提升检测速度。若是但愿使用一个检测对象检测多个数据,在每次检测完,必定要运行一下detector.reset()。清除以前的数据。
相关文章
相关标签/搜索