简单解决Python文件中文编码问题


这篇文章主要介绍了简单解决Python文件中文编码问题的相关资料,需要的朋友可以参考下

读写中文

需要读取utf-8编码的中文文件,先利用sublime text软件将它改成无DOM的编码,然后用以下代码:

with codecs.open(note_path, 'r+','utf-8') as f:
line=f.readline()
print line

这样就可以正确地读出文件里面的中文字符了。

同样的,如果要在创建的文件中写入中文,最好也和上面差不多:

with codecs.open(st,'a+','utf-8') as book_note:
book_note.write(st)

创建中文文件

然后以读出的字符为文件名,创建文件。

如果直接用上面读出来的字符串创建文件,则会出现:

st=digest_path+"\\"+onenote[0]+".txt"
print st
with open(st,'a+') as book_note:

经过调试,应该是最后一个换行符的问题,在生成名字的时候,将字符trip一下,就能够得到文件:

st=digest_path+"\\"+onenote[0].strip()+".txt"

中文编码问题是用中文的程序员经常头大的问题,在python下也是如此,那么应该怎么理解和解决python的编码问题呢?

我们要知道python内部使用的是unicode编码,而外部却要面对千奇百怪的各种编码,比如作为中国程序经常要面对的gbk,gb2312,utf8等,那这些编码是怎么转换成内部的unicode呢?

首先我们先看一下源代码文件中使用字符串的情况。源代码文件作为文本文件就必然是以某种编码形式存储代码的,python默认会认为源代码文件是asci编码,比如说代码中有一个变量赋值:

s1='a' 
print s1

python认为这个'a'就是一个asci编码的字符。在仅仅使用英文字符的情况下一切正常,但是如果用了中文,比如:

s1='哈' 
print s1

这个代码文件被执行时就会出错,就是编码出了问题。python默认将代码文件内容当作asci编码处理,但asci编码中不存在中文,因此抛出异常。

解决问题之道就是要让python知道文件中使用的是什么编码形式,对于中文,可以用的常见编码有utf-8,gbk和gb2312等。只需在代码文件的最前端添加如下:

# -*- coding: utf-8 -*-

这就是告知python我这个文件里的文本是用utf-8编码的,这样,python就会依照utf-8的编码形式解读其中的字符,然后转换成unicode编码内部处理使用。

不过,如果你在Windows控制台下运行此代码的话,虽然程序是执行了,但屏幕上打印出的却不是哈字。这是由于python编码与控制台编码的不一致造成的。Windows下控制台中的编码使用的

是gbk,而在代码中使用的utf-8,python按照utf-8编码打印到gbk编码的控制台下自然就会不一致而不能打印出正确的汉字。

解决办法一个是将源代码的编码也改成gbk,也就是代码第一行改成:

# -*- coding: gbk -*-

另一种方法是保持源码文件的utf-8不变,而是在'哈'前面加个u字,也就是:

s1=u'哈' 
print s1

这样就可以正确打印出'哈'字了。

这里的这个u表示将后面跟的字符串以unicode格式存储。python会根据代码第一行标称的utf-8编码识别代码中的汉字'哈',然后转换成unicode对象。如果我们用type查看一下'哈'的数据类型type(‘哈'),会得到<type ‘str'>,而type(u'哈'),则会得到<type ‘unicode'>,也就是在字符前面加u就表明这是一个unicode对象,这个字会以unicode格式存在于内存中,而如果不加u,表明这仅仅是一个使用某种编码的字符串,编码格式取决于python对源码文件编码的识别,这里就是utf-8。

Python在向控制台输出unicode对象的时候会自动根据输出环境的编码进行转换,但如果输出的不是unicode对象而是普通字符串,则会直接按照字符串的编码输出字符串,从而出现上面的现象。

使用unicode对象的话,除了这样使用u标记,还可以使用unicode类以及字符串的encode和decode方法。

unicode类的构造函数接受一个字符串参数和一个编码参数,将字符串封装为一个unicode,比如在这里,由于我们用的是utf-8编码,所以unicode中的编码参数使用'utf-8′将字符封装为

unicode对象,然后正确输出到控制台:

s1=unicode(‘哈', ‘utf-8′) 
print s1

另外,用decode函数也可以将一个普通字符串转换为unicode对象。很多人都搞不明白python字符串的decode和encode函数都是什么意思。这里简要说明一下。

decode是将普通字符串按照参数中的编码格式进行解析,然后生成对应的unicode对象,比如在这里我们代码用的是utf-8,那么把一个字符串转换为unicode就是如下形式:

s2='哈'.decode(‘utf-8′)

这时,s2就是一个存储了'哈'字的unicode对象,其实就和unicode(‘哈', ‘utf-8′)以及u'哈'是相同的。

那么encode正好就是相反的功能,是将一个unicode对象转换为参数中编码格式的普通字符,比如下面代码:

s3=unicode(‘哈', ‘utf-8′).encode(‘utf-8′)

s3现在又变回了utf-8的'哈'。

<think>我们正在解决Python绘图中文乱码的问题。根据引用,有几种方法可以解决:1.设置rcParams参数,使用系统支持的中文字体(如SimHei、WenQuanYi MicroHei等)2.使用字体管理器指定字体文件路径注意:不同的操作系统和字体环境可能需要不同的设置。步骤:方法一:使用rcParams(适用于Windows和Linux,但需要系统有相应字体)```pythonimportmatplotlib.pyplotas pltplt.rcParams['font.sans-serif']= ['SimHei']#用来正常显示中文标签plt.rcParams['axes.unicode_minus'] =False#用来正常显示负号```方法二:如果系统没有SimHei字体(如某些Linux系统),可以尝试其他字体,如:```pythonplt.rcParams['font.sans-serif'] =['WenQuanYiMicro Hei']#文泉驿微米黑```方法三:通过字体管理器指定字体文件路径(适用于自定义字体或字体不在默认路径)```pythonimport matplotlib.font_manageras fmimport matplotlib.pyplot asplt#指定字体文件路径(例如Windows下的宋体)font_path ='C:/Windows/Fonts/simsun.ttc'my_font =fm.FontProperties(fname=font_path)#然后在绘图指定字体,例如:plt.title('标题',fontproperties=my_font)plt.xlabel('x轴',fontproperties=my_font)#注意:这种方法需要在每个文本设置中单独指定```注意:在Linux系统中,可能需要安装中文字体包,例如:Ubuntu:`sudo apt-get installfonts-wqy-microhei`安装文泉驿微米黑或者 `sudo apt-get installfonts-wqy-zenhei`安装文泉驿正黑根据引用[1]和[2],方法一和方法二都是通过设置rcParams来全局设置字体,这样就不需要在每次绘制文本都指定字体。而方法三则适用于需要特定字体的情况,但需要每次设置。因此,推荐使用方法一或方法二进行全局设置,简单方便。但是,如果出现设置后仍乱码,可能是字体名称不正确,可以通过以下代码查看可用字体:```pythonfrommatplotlib.font_manager importfontManagerfont_list =[font.name forfont infontManager.ttflist]print(font_list)```然后选择一种中文字体名称进行设置。另外,引用[3]提到在Python3下修改配置文件的方法,但通常我们更推荐在代码中动态设置。总结:最常用的方法是设置plt.rcParams,使用系统已有的中文字体。例如,在Windows中,通常使用'SimHei'(黑体)或'KaiTi'(楷体)等;在Linux中,可以使用文泉驿字体(如'WenQuanYiMicro Hei')。下面是一个完整的示例:</think>### 解决Python绘图中文乱码问题Python中使用Matplotlib绘图中文显示乱码的根本原因是默认字体不支持中文字符。以下是几种有效的解决方案: #### 方法一:全局设置字体(推荐) ```python import matplotlib.pyplot as plt # 设置中文字体(Windows系统) plt.rcParams['font.sans-serif'] = ['SimHei'] # 黑体 # plt.rcParams['font.sans-serif'] = ['Microsoft YaHei'] # 微软雅黑 # 设置负号显示 plt.rcParams['axes.unicode_minus'] = False # 示例绘图 plt.title('中文标题测试') plt.xlabel('X轴标签') plt.ylabel('Y轴标签') plt.plot([1,2,3], [4,5,6]) plt.show() ``` #### 方法二:Linux系统字体设置 ```python # 适用于Linux系统(需安装文泉驿字体) plt.rcParams['font.sans-serif'] = ['WenQuanYi Micro Hei'] plt.rcParams['axes.unicode_minus'] = False ``` #### 方法三:指定字体文件路径 ```python from matplotlib.font_manager import FontProperties import matplotlib.pyplot as plt # 直接指定字体文件路径 myfont = FontProperties(fname='C:/Windows/Fonts/simhei.ttf') # Windows路径 # myfont = FontProperties(fname='/usr/share/fonts/wenquanyi.ttf') # Linux路径 # 绘图单独指定字体 plt.title('中文标题', fontproperties=myfont) plt.xlabel('X轴', fontproperties=myfont) plt.plot([1,2,3], [4,5,6]) plt.show() ``` #### 常见问题排查: 1. **字体名称错误**:通过`print(plt.rcParams['font.sans-serif'])`查看可用字体列表 2. **字体文件缺失**:确保系统中安装了对应字体(如Linux需执行`sudo apt install fonts-wqy-microhei`) 3. **环境重置问题**:在Jupyter中需在每次启动重新设置 4. **特殊字符问题**:单独设置`axes.unicode_minus`解决负号显示异常 > 实践表明,全局设置`plt.rcParams`是最稳定高效的解决方案[^1][^2][^3]。Windows系统推荐使用`SimHei`或`Microsoft YaHei`,Linux系统推荐使用`WenQuanYi Micro Hei`字体。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值