拜师——python基础入门—第十大节课—编码介绍 中文乱码问题解决——day44

本文主要是介绍拜师——python基础入门—第十大节课—编码介绍 中文乱码问题解决——day44,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第137课时: 编码介绍 中文乱码问题解决



常用编码介绍:

在操作文本文件时,经常会操作中文,这时候就经常会碰到乱码问题。为了让大家有能力解决中文乱码问题,这里简单介绍一下各种编码之间的关系。

测试代码:

f = open(r"b.txt","a")
s = "王立宗\nsxt\n"
f.write(s)
f.close()

运行结果,可以看到,在d盘生成了一个txt文件
在这里插入图片描述

打开直观文件后发现,中文字符成了乱码
在这里插入图片描述

在这里插入图片描述
常见字符的关系图

ASCII

全称为 American Standard Code for Information Interchange,美国信息交换标准代码,这是世界上最早最通用的单字节编码系统,主要用来显示现代 英语及其他西欧语言。
ASCII 码用 7 位表示,只能表示 128 个字符

ISO8859-1

ISO-8859-1 又称 Latin-1,是一个 8 位单字节字符集,它把 ASCII 的最高位也利用起来,并兼容了ASCII,新增的空间是 128,但它并没有完全用完。在ASCII 编码之上又增加了西欧语言、希腊语、泰语、阿拉伯语、希伯来语

对应的文字符号,它是向下兼容ASCII 编码

GB2312,GBK,GB18030

GB2312 全称为信息交换用汉字编码字符集,是中国于 1980 年发布,主要用于计算机系统中的汉字处理。GB2312 主要收录了 6763 个汉字、682 个符号。 GB2312覆盖了汉字的大部分使用率,但不能处理像古汉语等特殊的罕用字,
所以后来出现了像GBK、GB18030 这种编码。

•GB18030

现在最新的内码字集于 2000 年发布,并于 2001 年强制执行,包含了中国大部分少数
民族的语言字符,收录汉字数超过 70000 余个。 它主要采用单字节、双字节、四字节对字符编码,它是向下兼容 GB2312 和GBK 的,
虽然是我国的强制使用标准,但在实际生产中很少用到,用得最多的反而是 GBK 和GB2312

Unicode

(万国码。)

Unicode编码设计成了固定两个字节,所有的字符都用 16 位(2^16=65536)
表示,包括之前只占 8 位的英文字符等,所以会造成空间的浪费,UNICODE 在 很长的一段时间内都没有得到推广应用。

所有符号;两个字节一个字符。

Unicode 完全重新设计,不兼容 iso8859-1,也不兼容任何其他编码

UTF-8(文件存储用它,程序内部操作n=用unicode)

对于英文字母,unicode 也需要两个字节来表示。所以 unicode 不便于传输和存储。因此而产生了UTF 编码,UTF-8 全称是(8-bit Unicode Transformation Format)。 UTF 编码兼容 iso8859-1 编码,同时也可以用来表示所有语言的字符,

不过,UTF 编码是不定长编码,每一个字符的长度从 1-4 个字节不等。

其中, 英文字母都是用一个字节表示,而汉字使用三个字节。


【老鸟建议】

一般项目都会使用UTF-8。unicode 中虽然汉字是两个字节,

UTF-8 中汉字是 3 个字节。但是互联网中一个网页也包含了大量的英文字母, 这些英文字母只占用 1 个字节,整体占用空间,UTF-8 仍然优于Unicode。

Python程序中默认使用unicode,


中文乱码问题:

windows 操作系统默认的编码是 GBK,Linux 操作系统默认的编码是 UTF-8。
当我们用 open()时,调用的是操作系统打开的文件,默认的编码是GBK。

Python用的编码是 Unicode 而电脑系统是gbk

所以python用Unicode ,而电脑系统生成文件是用gbk格式
所以在python中打开必须用gbk

所以打开文件时用gbk
在这里插入图片描述
点击gbk
在这里插入图片描述
出现正常的字符。


如果我们想生成的文件就是固定的格式,可以如下操作

f = open(r"b.txt","a",encoding='utf-8')
s = "王立宗\nsxt\n"
f.write(s)
f.close()

可以看到,我们后写入的就是utf-8格式
在这里插入图片描述

这篇关于拜师——python基础入门—第十大节课—编码介绍 中文乱码问题解决——day44的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/414920

相关文章

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

zookeeper端口说明及介绍

《zookeeper端口说明及介绍》:本文主要介绍zookeeper端口说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、zookeeper有三个端口(可以修改)aVNMqvZ二、3个端口的作用三、部署时注意总China编程结一、zookeeper有三个端口(可以

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

Python包管理工具pip的升级指南

《Python包管理工具pip的升级指南》本文全面探讨Python包管理工具pip的升级策略,从基础升级方法到高级技巧,涵盖不同操作系统环境下的最佳实践,我们将深入分析pip的工作原理,介绍多种升级方... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert