python第三方库-字符串编码工具 chardet 的使用(python3经典编程案例)

简介: 这篇文章介绍了如何使用Python的第三方库chardet来检测字符串的编码类型,包括ASCII、GBK、UTF-8和日文编码的检测示例。

一. chardet介绍

chardet这个第三方库的使用非常容易,chardet支持检测中文、日文、韩文等多种语言。

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

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

官方文档:https://chardet.readthedocs.io/en/latest/

github地址:https://github.com/chardet/chardet

安装:pip3 install chardet

截至目前,可以检测的编码:

  • ASCII, UTF-8, UTF-16 (2 variants), UTF-32 (4 variants)
  • Big5, GB2312, EUC-TW, HZ-GB-2312, ISO-2022-CN (Traditional and Simplified Chinese)
  • EUC-JP, SHIFT_JIS, CP932, ISO-2022-JP (Japanese)
  • EUC-KR, ISO-2022-KR, Johab (Korean)
  • KOI8-R, MacCyrillic, IBM855, IBM866, ISO-8859-5, windows-1251 (Cyrillic)
  • ISO-8859-5, windows-1251 (Bulgarian)
  • ISO-8859-1, windows-1252 (Western European languages)
  • ISO-8859-7, windows-1253 (Greek)
  • ISO-8859-8, windows-1255 (Visual and Logical Hebrew)
  • TIS-620 (Thai)

二. 使用chardet

2.1 检测编码是ascii

当我们拿到一个bytes时,就可以对其检测编码。用chardet检测编码,只需要一行代码:

import chardet
print(chardet.detect(b'Hello, world!'))

# 运行结果
# 检测出的编码是ascii,注意到还有个confidence字段,表示检测的概率是1.0(即100%)。
{
   'encoding': 'ascii', 'confidence': 1.0, 'language': ''}
2.2 检测GBK编码:
import chardet
data = '真相只有一个'.encode('gbk')
print(chardet.detect(data))

# 运行结果
# 检测的编码是GB2312,注意到GBK是GB2312的超集,两者是同一种编码,检测正确的概率是99%,
# language字段指出的语言是'Chinese'。
{
   'encoding': 'GB2312', 'confidence': 0.99, 'language': 'Chinese'}
2.3 对UTF-8编码进行检测
import chardet
data = '真相只有一个'.encode('utf-8')
print(chardet.detect(data))

# 运行结果
{
   'encoding': 'utf-8', 'confidence': 0.99, 'language': ''}
2.4 检测日文
import chardet
data = '真実はいつもひとつ'.encode('euc-jp')
print(chardet.detect(data))

# 运行结果
{
   'encoding': 'EUC-JP', 'confidence': 1.0, 'language': 'Japanese'}

可见,用chardet检测编码,非常简单。获取到编码后,再转换为str,就可以方便后续处理。

相关文章
|
6月前
|
Python
Python编程:运算符详解
本文全面详解Python各类运算符,涵盖算术、比较、逻辑、赋值、位、身份、成员运算符及优先级规则,结合实例代码与运行结果,助你深入掌握Python运算符的使用方法与应用场景。
415 3
|
6月前
|
数据处理 Python
Python编程:类型转换与输入输出
本教程介绍Python中输入输出与类型转换的基础知识,涵盖input()和print()的使用,int()、float()等类型转换方法,并通过综合示例演示数据处理、错误处理及格式化输出,助你掌握核心编程技能。
631 3
|
6月前
|
并行计算 安全 计算机视觉
Python多进程编程:用multiprocessing突破GIL限制
Python中GIL限制多线程性能,尤其在CPU密集型任务中。`multiprocessing`模块通过创建独立进程,绕过GIL,实现真正的并行计算。它支持进程池、队列、管道、共享内存和同步机制,适用于科学计算、图像处理等场景。相比多线程,多进程更适合利用多核优势,虽有较高内存开销,但能显著提升性能。合理使用进程池与通信机制,可最大化效率。
439 3
|
6月前
|
Java 调度 数据库
Python threading模块:多线程编程的实战指南
本文深入讲解Python多线程编程,涵盖threading模块的核心用法:线程创建、生命周期、同步机制(锁、信号量、条件变量)、线程通信(队列)、守护线程与线程池应用。结合实战案例,如多线程下载器,帮助开发者提升程序并发性能,适用于I/O密集型任务处理。
587 0
|
数据采集 Python
如何从 Python 中的字符串列表中删除特殊字符?
如何从 Python 中的字符串列表中删除特殊字符?
707 0
|
存储 安全 Serverless
Python学习四:流程控制语句(if-else、while、for),高级数据类型(字符串、列表、元组、字典)的操作
这篇文章主要介绍了Python中的流程控制语句(包括if-else、while、for循环)和高级数据类型(字符串、列表、元组、字典)的操作。
437 0
|
Python
Python操作:字符串--列表--元组--字典--运算符 (一)
Python操作:字符串--列表--元组--字典--运算符 (一)
208 0
|
Python
Python操作:字符串--列表--元组--字典--运算符 (二)
Python操作:字符串--列表--元组--字典--运算符 (二)
171 0
|
存储 数据安全/隐私保护 索引
Python基础语法day02字符串详解和列表
Python基础语法day02字符串详解和列表
|
存储 索引 Python
Python基础 笔记(七) 容器--字符串、列表
Python基础 笔记(七) 容器--字符串、列表
178 4

推荐镜像

更多