python使用chardet判断字符串编码的方法

作者:liuli 时间:2023-02-02 06:45:20 

本文实例讲述了python使用chardet判断字符串编码的方法。分享给大家供大家参考。具体分析如下:

最近利用python抓取一些网上的数据,遇到了编码的问题。非常头痛,总结一下用到的解决方案。

linux中vim下查看文件编码的命令 set fileencoding
python中一个强力的编码检测包 chardet ,使用方法非常简单。linux下利用pip install chardet实现简单安装


import chardet
f = open('file','r')
fencoding=chardet.detect(f.read())
print fencoding

fencoding输出格式 {'confidence': 0.96630842899499614, 'encoding': 'GB2312'} ,只能判断是否为某种编码的概率。比较准确的结果了。输入参数为str类型。

了解python中str的编码后可以利用decode和encode来实现编码的转换。

一般流程是str利用decode方法根据str的编码将其解码为unicode字符串类型,然后利用encode根据特定的编码将unicode字符串类型转换为特定的编码。python中str和unicode属于两种不同的类型,如下。

一般情况下window默认编码gbk,linux默认编码utf8
python编程中 系统编码,python编码,文件编码 的概念。

系统编码:默认写源码的编辑器的编码方式。它代表源码文件内的所有内容都是根据词方式编码成二进制码流。存入到磁盘中的。linux下通过locale命令查看。

python编码:指python内设置的解码方式。如果不设定的话,python默认的是ascii解码方式。如果python源代码文件中不出现中文的话,这个地方怎么设定应该不会问题。

设定方法:在源码文件开头(一定是第一行):#-*-coding:UTF-8-*-,源码文件的设置解码方式是UTF-8 或者 


import sys
reload(sys)
sys.setdefaultencoding('UTF-8')

文件编码:文本的编码方式,linux下vim利用set fileencoding查看。

一般情况下输出乱码的原因就是 没有按照系统解码的方式进行编码。

比如print s, s类型为str,linux系统下系统默认编码为utf8编码,s在输出前就应该编码为utf8。如果s为gbk编码就应该这样输出。print s.decode('gbk').encode('utf8')才能输出中文。

window下面情况相同,window默认编码为gbk编码,所以s输出前必须编码为gbk。

python处理中一般处理unicode类型。这样输出前直接编码即可。

希望本文所述对大家的Python程序设计有所帮助。

标签:python,字符串,编码
0
投稿

猜你喜欢

  • Python使用Scrapy爬取妹子图

    2022-06-17 23:47:41
  • mysql通过查看跟踪日志跟踪执行的sql语句

    2024-01-28 00:56:10
  • 国内ASP开源建站系统一览

    2009-07-10 13:21:00
  • 原生js拖拽实现图形伸缩效果

    2024-04-16 08:55:27
  • Python logging日志模块 配置文件方式

    2021-03-07 04:31:01
  • Linux+Nginx+MySQL下配置论坛程序Discuz的基本教程

    2024-05-11 10:46:59
  • 解决numpy矩阵相减出现的负值自动转正值的问题

    2021-10-07 19:49:16
  • OpenCV半小时掌握基本操作之圆圈检测

    2022-09-17 08:07:50
  • python计算机视觉opencv图像金字塔轮廓及模板匹配

    2021-10-10 09:15:33
  • 重新阅读《HTTP协议基础》

    2008-04-04 17:40:00
  • PHP的PDO错误与错误处理

    2023-06-05 20:21:40
  • Vue实现聊天界面

    2024-04-28 09:23:57
  • Python 的类、继承和多态详解

    2021-05-29 17:31:51
  • python 实现敏感词过滤的方法

    2022-08-09 10:22:51
  • 关于networkx返回图的邻接矩阵问题

    2021-04-09 13:10:35
  • 详解ASP图片上传保存到数据库功能

    2008-01-25 18:47:00
  • Python中使用logging和traceback模块记录日志和跟踪异常

    2023-09-20 16:08:51
  • 浅谈vue-lazyload实现的详细过程

    2024-04-29 13:09:17
  • 详解Python开发语言中的基本数据类型

    2022-12-11 20:13:35
  • Python代码部署的三种加密方案

    2022-03-22 02:24:40
  • asp之家 网络编程 m.aspxhome.com