博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python 模块 chardet下载及介绍(转)
阅读量:7233 次
发布时间:2019-06-29

本文共 1139 字,大约阅读时间需要 3 分钟。

  hot3.png

python 模块 chardet下载及介绍(转)

在处理字符串时,常常会遇到不知道字符串是何种编码,如果不知道字符串的编码就不能将字符串转换成需要的编码。面对多种不同编码的输入方式,是否会有一种有效的编码方式?chardet是一个非常优秀的编码识别模块。
chardet 是python的第三方库,需要下载和安装。下载的地址有:
1.推荐地址:   
2.官方地址:  
如果采用源代码安装方法,有可能会提示缺少setuptools这个模块。因此这里我们采用另外一种更为方便的安装方法,不论你选择哪种安装包,将它解压得到其中的文件夹【chardet】将这个文件夹复制到【python安装根目录\Lib\site-packages】下,确保这个位置可以被python引用到。如果不能被引用到请加入环境变量。
在安装完chardet模块,我就可以使用它了,来看一段示例代码。
[python] 
  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] 
  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'}  

级的方法,可以只读一部,去判别编码方式从而提高检测速度。如果希望使用一个检测对象检测多个数据,在每次检测完,一定要运行一下detector.reset()。清楚之前的数据。

本文转自:,感谢原博客!

转载于:https://my.oschina.net/dillan/blog/131231

你可能感兴趣的文章
Objective-C中的一些特殊的数据类型
查看>>
C++关键字
查看>>
Kruskal算法的思想、证明及步骤
查看>>
来自 Google 的 R 语言编码风格指南
查看>>
常用的Mysql数据库操作语句大全
查看>>
iOS 新手指引在App中的添加,第一次启动应用程序出现,后面都不出现
查看>>
Mac使用笔记
查看>>
深入Mysql字符集设置
查看>>
利用Ajax无刷新更新rss阅读
查看>>
GCC 64位程序的makefile条件编译心得——32位版与64位版、debug版与release版(兼容MinGW、TDM-GCC)...
查看>>
测试Varnish缓存服务器与IIS连接数
查看>>
POJ 2396 Budget
查看>>
编程之美:求二进制中1的个数
查看>>
Qt中父子widget的消息传递(转)
查看>>
vim 代码提示功能,让vim可以媲美IDE(转)
查看>>
IO笔记总结
查看>>
位棋盘表示法中车和炮的着法生成
查看>>
Arch Linux 安装 ibus 五笔输入法备忘录
查看>>
第38周星期二
查看>>
在VS2010里可以给JS函数添加代码提示\注释
查看>>