位置: 编程技术 - 正文

简单解决Python文件中文编码问题(python问题及解决方法)

编辑:rootadmin

推荐整理分享简单解决Python文件中文编码问题(python问题及解决方法),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:python文件处理方法,python问题及解决方法,python处理文档,python 文本文件处理,python 文本文件处理,python文件wt,python文件wt,python处理文档,内容如对您有帮助,希望把文章链接给更多的朋友!

读写中文

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

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

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

创建中文文件

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

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

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

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

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

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

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

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

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

简单解决Python文件中文编码问题(python问题及解决方法)

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

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

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

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

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

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

这里的这个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对象,然后正确输出到控制台:

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

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

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

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

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

Python中time模块与datetime模块在使用中的不同之处 Python中提供了对时间日期的多种多样的处理方式,主要是在time和datetime这两个模块里。今天稍微梳理一下这两个模块在使用上的一些区别和联系。time在P

python 多线程实现检测服务器在线情况 需要ping一个网段所有机器的在线情况,shell脚步运行时间太长,用python写个多线程ping吧,代码如下:#!/usr/bin/python#coding=utf-8'''Createdon-8-4@author:Administr

python基础知识小结之集合 集合特点:集合对象是一组无序排列的可哈希的值:集合成员可以做字典的键,与列表和元组不同,集合无法通过数字进行索引。此外,集合中的元素

标签: python问题及解决方法

本文链接地址:https://www.jiuchutong.com/biancheng/379926.html 转载请保留说明!

上一篇:Python制作简单的网页爬虫(python制作简单图形)

下一篇:Python中time模块与datetime模块在使用中的不同之处(Python中time模块中的方法)

  • 印花税减免税优惠政策202
  • 房产契税是怎样计算的
  • 个体户缴纳经营所得个税怎么算的
  • 调整未分配利润影响所得税吗
  • 普票千元版和万元版板面区别
  • 要补交税怎么办
  • 其他应收款对方科目是啥
  • 财务软件要入固定资产吗
  • 租赁合同印花税税率2023
  • 百旺红字发票申领流程
  • 未达起征点销售额,11栏怎么填写
  • 发票查询显示无数据怎么回事
  • 退休职工的医疗保险怎么发放
  • 物业公司水费差额征税不备案
  • 个税申报初始密码一定要去所属税局看吗
  • 租赁服务可以享受加计抵减吗
  • 软件开发过程中必须伴有质量保证活动
  • 建筑施工企业在12个月内连续发生
  • 调整会计分录是什么
  • 人工费没有发票年度汇算调增需要进行调帐处理吗
  • Win10 Build 18363.1350/17763.1728累积更新补丁KB4598298正式推送
  • 网吧登录qq安全吗
  • 远程主机强迫关闭了现有连接我的世界
  • 笔记本电脑按键掉了怎么修
  • 土地出让金可以代缴吗
  • 企业购入旧设备怎么入账
  • 债务重组利得计入投资收益还是营业外收入
  • nicconfigsvc.exe - nicconfigsvc是什么进程 有什么用
  • 非货币性资产投资计入什么科目
  • 微信小程序登录的账号怎么注销
  • 治疗孩子咳嗽小秘方,超实用
  • vue中使用require报错
  • .gp4
  • 企业预付账款怎么做账
  • 收到商业承兑汇票怎么兑现
  • 帝国cms灵动标签下拉框
  • 经营结余是指事业单位在本年度经营活动
  • 发行股票会计怎么做分录
  • 提供劳务收入包含什么
  • 未计提坏账准备发生坏账如何处理
  • 工程项目立项前的安全评估
  • 工程施工怎么结转,用友自动结转吗
  • 单位注销合并劳动合同有效吗
  • 企业汇算清缴调整费用后资产负债表怎么改
  • 零售商品收入
  • 购买银行理财产品的几个必须知道
  • 包装物属于周转材料还是低值易耗品
  • 主营业务成本和管理费用的区别
  • 纳税人办理逾期申报流程
  • 收到退回多付的材料退款
  • 开票金额大于付款金额 多余部分为返点
  • 库存现金盘点表监盘人是谁
  • 库存的周转天数
  • sql语句版本
  • windows的使用
  • SsAAD.exe - SsAAD是什么进程
  • win7系统共享打印机设置方法
  • 盘点十大最流行歌曲
  • 怎么有才能
  • win7系统安装教程不用u盘
  • 三种方法完美解决问题
  • 简洁桌面怎么设置
  • win10播放视频的软件
  • win7系统开机黑屏如何处理
  • 解决的英文
  • win10系统怎么关闭病毒防护
  • jQuery实现select模糊查询(反射机制)
  • 讯飞src
  • shell 判断进程是否存在
  • javascript边框
  • nodejs开发微信小程序
  • nodejs基础教程
  • jquery加载图片
  • python deque
  • unity3d的作用
  • 厂房转让的土地税怎么算
  • 如何在网上开税票发票
  • 加计抵减怎么计提分录
  • 出口退税申报已通过,又被删除,报关单号能用吗
  • 衡阳地税局的地理位置
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设