python 模块 chardet下载及介绍

本文介绍了chardet模块,这是一个用于识别字符串编码的优秀Python第三方库。提供了两种使用方法,包括基本用法和针对大型文件的高级应用示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

python 模块 chardet下载及介绍

 
在处理字符串时,常常会遇到不知道字符串是何种编码,如果不知道字符串的编码就不能将字符串转换成需要的编码。面对多种不同编码的输入方式,是否会有一种有效的编码方式?chardet是一个非常优秀的编码识别模块。
chardet 是python的第三方库,需要下载和安装。下载的地址有:
 
如果采用源代码安装方法,有可能会提示缺少setuptools这个模块。因此这里我们采用另外一种更为方便的安装方法,不论你选择哪种安装包,将它解压得到其中的文件夹【chardet】将这个文件夹复制到【python安装根目录\Lib\site-packages】下,确保这个位置可以被python引用到。如果不能被引用到请加入环境变量。
 
在安装完chardet模块,我就可以使用它了,来看一段示例代码。
[python]  view plaincopy
 
1 import chardet  
2 import urllib  
3   
4 #可根据需要,选择不同的数据  
5 TestData = urllib.urlopen('http://www.baidu.com/').read()  
6 print chardet.detect(TestData)  
7   
8 运行结果:  
9 {'confidence': 0.99, 'encoding': 'GB2312'}  
运行结果表示有99%的概率认为这段代码是GB2312编码方式。
 
另外一个相对高级的应用。
[python]  view plaincopy
 
 1 import urllib  
 2 from chardet.universaldetector import UniversalDetector  
 3 usock = urllib.urlopen('http://www.baidu.com/')  
 4 #创建一个检测对象  
 5 detector = UniversalDetector()  
 6 for line in usock.readlines():  
 7     #分块进行测试,直到达到阈值  
 8     detector.feed(line)  
 9     if detector.done: break  
10 #关闭检测对象  
11 detector.close()  
12 usock.close()  
13 #输出检测结果  
14 print detector.result  
15   
16 运行结果:  
17 {'confidence': 0.99, 'encoding': 'GB2312'}  

 

应用背景,如果要对一个大文件进行编码识别,使用这种高级的方法,可以只读一部,去判别编码方式从而提高检测速

 

 

来源:http://blog.youkuaiyun.com/tianzhu123/article/details/8187470/

posted on 2018-06-27 11:15 Ella_Wu 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/wuaihua/p/9232999.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值