iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >python系统编码-稍后更新
  • 221
分享到

python系统编码-稍后更新

稍后系统python 2023-01-31 02:01:44 221人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

安装IDLE (python GUI)时,默认的编码是ascii,当程序中出现非ascii编码时,Python的处理常常会报这样的错UnicodeDecodeError: 'ascii' codec can't decode byte

安装IDLE (python GUI)时,默认的编码是ascii,当程序中出现非ascii编码时,Python的处理常常会报这样的错UnicodeDecodeError: 'ascii' codec can't decode byte 0x?? in position 1: ordinal not in range(128),python没办法处理非ascii编码的,此时需要自己设置将python的默认编码,一般设置为utf8的编码格式。

查询系统默认编码可以在解释器中输入以下命令

sys.getdefaultencoding()

设置默认编码时:

sys.setdefaultencoding('utf8')

可能会报AttributeError: 'module' object has no attribute 'setdefaultencoding'的错误,执行reload(sys),在执行以上命令就可以顺利通过。

此时在执行sys.getdefaultencoding()就会发现编码已经被设置为utf8的了,但是在解释器里修改的编码只能保证当次有效,在重启解释器后,会发现,编码又被重置为默认的ascii了,那么有没有办法一次性修改程序或系统的默认编码呢。

1.(建议)python的Lib\site-packages文件夹下新建一个sitecustomize.py。内容为:

此时重启python解释器,执行sys.getdefaultencoding(),发现编码已经被设置为utf8的了,多次重启之后,效果相 同,这是因为系统在python启动的时候,自行调用该文件,设置系统的默认编码,而不需要每次都手动的加上解决代码,属于一劳永逸的解决方法。

2.在程序中加入以下代码:

import sys
reload(sys)
sys.setdefaultencoding('utf8')

另外有一种解决方案是在程序中所有涉及到编码的地方,强制编码为utf8,即添加代码encode("utf8"),这种方法并不推荐使用,因为一 旦少写一个地方,将会导致大量的错误报告,我曾经遇到这种情况,错误日志压缩之后尚有70多K,全都是这一个问题,让人有很崩溃的感觉

python编译器,有多种,本人目前常用Eclipse+pyde,效果还好,编码问题不大,用codecs及decode、encode可以解决大部分。另外要注意,在字符串前面加u或者r,转为unicode编码或者转义,缺少u或者r,不清楚编码真的很头疼。


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

  •     linux中vim下查看文件编码的命令 set fileencoding

  •     python中一个强力的编码检测包 chardet ,使用方法非常简单。linux下利用pip install chardet实现简单安装

 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 或者


 文件编码:文本的编码方式,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类型。这样输出前直接编码即可。



一、首先,请选择python3.x最新版本。 
  
因为最新版本的编码问题相对于之前的2.0版本要好不少。 
  
二、在编写程序代码时,习惯性地在代码开始处加上下面的语句。 

默 认地,python的.py文件以标准的7位ASCII码存储,而不是unicode格式的,然而如果有的时候用户需要在.py文件中包含很多的 unicode字符,例如.py文件中需要包含中文的字符串,这时可以在.py文件的第一行或第二行增加encoding注释来将.py文件指定为 unicode格式。

#!/usr/bin/env python   #设置Python解释器
# -*- coding: UTF-8 -*-   #声明文件编码为utf-8

s = "中国" # String in quotes is directly encoded in UTF-8. 
  
三、编写完代码,把代码存储成.py文件时确保文件编码与声明一致。 
  
当你编写完代码,把代码存储成.py文件时,一定要将文件编码设为与开头的文件编码声明一致的编码(如:声明为# -*- coding: UTF-8 -*-,则可以通过使用notepad++等软件指定.py文件为utf-8编码)。

#获取文件的默认编码

import sys

print(sys.getdefaultencoding()) 

#设置python文件的编码

#encoding=uft-8

import sys

reload(sys)

sys.setdefaultencoding('utf-8')

  
四、python3.2版本中对文件的读写操作都要指明编码。 
  
参考代码如下: 
f =  open("1.txt","r",encoding="utf-8")

当然也可以使用codecs包进行文件的读取,在使用open()函数时指定编码的类型:

import codecs

f=codecs.open('123.txt','r+',encoding='utf-8) 
  
五、python3.2版本中对于要读取的文件,如果文件的编码并不知道,可以先使用chardet(第三方库,需要下载)来进行判断,然后再根据判断所得的文件编码类型,指定文件的编码类型来进行文件的读取操作。 
  
参考代码如下: 
file =  open(fileName, "rb")#要有"rb",如果没有这个的话,默认使用gbk读文件。           
buf = file.read()   
result = chardet.detect(buf)   
file = open(fileName,"r",encoding=result["encoding"])   
content = file.readlines() 

 

使用中,chardet.detect()返回字典,其中confidence是检测精确度,encoding是编码形式 
  
(1)网页编码判断: 
  
>>> import urllib 
>>> rawdata = urllib.urlopen('Http://www.Google.cn/').read() 
>>> import chardet 
>>> chardet.detect(rawdata) 
  
检测的结果是:{'confidence': 0.98999999999999999, 'encoding': 'GB2312'} 
  
(2)文件编码判断 
  
import chardet 
tt=open('c:\\111.txt','rb') 
ff=tt.readline()#这里试着换成read(5)也可以,但是换成readlines()后报错 
enc=chardet.detect(ff) 
print enc['encoding'] 
tt.close() 

另外为了提高探测速度,可使用如下方式:
detector = UniversalDetector() 
for line in f.readlines(): 
      detector.feed(line) 
      if detector.done: 
          break 
detector.close() 
detector.result  

(3)字符串编码的判断

    isinstance(s,str) 用来判断是否为一般字符串

    isinstance(s,unicode)  用来判断是否为unicode

或者:

    if type(str).__name__!="unicode":

         str=unicode(str,"utf-8")

    else:

          pass.

Python的encode和decode的用法:

无论是在python2.0还是在python3.0中,在做编码转换时,都通常以unicode做为中间编码,即先将其他编码的字符串解码(decode)成unicode,再从unicode编码(encode)成另一种编码。

一、Python2.0

          decode                           encode

str--------------------->unicode----------------->str

如:  str=u"中文"   #指定str为unicode类型对象

      uni=str.encode('gb2312')      #unicode编码转换为gb2312编码

二、Python3.0

        在新版的python3.0中,取消了unicode类型,代替它的是使用unicode字符的字符串类型str:

         decode                         encode

bytes------------>str(unicode)----->bytes

注: 代码中的字符串的默认编码与代码文件本身的编码是一致的,如:s=“中文",若在utf8的文件中,该字符串就是utf8编码,此时要进行编码转换,都需 要先用decode方法将其转换为unicode编码,在使用encode方法将其转换成其他编码。在没有指定特定的编码方式时,使用系统默认编码。

s=u"中文"

则该字符串的编码已被指定为unicode了,即python的内部编码,而与文件本身的编码无关。此时,只需要使用encode方法就可以将其转换成指定编码即可。如果字符串已经是unicode时,再进行解码会出错,这是就需要判断其编码方式是否为unicode:

   isinstance(s,unicode)

用非unicode编码形式的str来encode也会报错。

unicode(str,gb2312)与str.decode(gb2312)一样,都将gb2312编码的str转为unicode编码。

python2和python3中str的比较:

初学Python的简单文件操作编码问题 - changfengmingzhi - 长风明志的博客

python3中的str的转化函数:

初学Python的简单文件操作编码问题 - changfengmingzhi - 长风明志的博客

 

 可能需要str的转化的情况:

初学Python的简单文件操作编码问题 - changfengmingzhi - 长风明志的博客

 可能需要str的转化的情况:

初学Python的简单文件操作编码问题 - changfengmingzhi - 长风明志的博客



无需操作系统直接运行 Python 代码  http://www.linuxidc.com/Linux/2015-05/117357.htm

Centos上源码安装Python3.4  http://www.linuxidc.com/Linux/2015-01/111870.htm

《Python核心编程 第二版》.(Wesley J. Chun ).[高清pdf中文版] http://www.linuxidc.com/Linux/2013-06/85425.htm

《Python开发技术详解》.( 周伟,宗杰).[高清PDF扫描版+随书视频+代码] http://www.linuxidc.com/Linux/2013-11/92693.htm

Python脚本获取Linux系统信息 http://www.linuxidc.com/Linux/2013-08/88531.htm

ubuntu下用Python搭建桌面算法交易研究环境 http://www.linuxidc.com/Linux/2013-11/92534.htm

Python 语言的发展简史 http://www.linuxidc.com/Linux/2014-09/107206.htm

Python 的详细介绍:请点这里
Python 的下载地址:请点这里

本文永久更新链接地址:http://www.linuxidc.com/Linux/2015-06/118734.htm


--结束END--

本文标题: python系统编码-稍后更新

本文链接: https://www.lsjlt.com/news/185991.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • python系统编码-稍后更新
    安装IDLE (Python GUI)时,默认的编码是ascii,当程序中出现非ascii编码时,python的处理常常会报这样的错UnicodeDecodeError: 'ascii' codec can't decode byte ...
    99+
    2023-01-31
    稍后 系统 python
  • linux之系统编码,python编码,
    如果你对python2和python3的中编解码很清楚,这里我认为你很清楚。具体参考文档:“python2 encode和decode函数说明.docx”“字符编码——从ASCII开始.docx”以上所有文档均为本地文档。sys.getde...
    99+
    2023-01-31
    系统 linux python
  • 用python查看和更改系统默认编码
    用python查看和更改系统默认编码   python在安装时,默认的编码是ascii,当程序中出现非ascii编码时,python的处理常常会报这样的错UnicodeDecodeError: 'ascii' codec c...
    99+
    2023-01-31
    系统 python
  • win10系统更新后黑屏如何解决
    这篇“win10系统更新后黑屏如何解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“win10系统更新后黑屏如何解决”文章吧...
    99+
    2023-07-01
  • Ubuntu20.04下更新系统Python版本
    起因:写Python时报错: TypeError: unsupported operand type(s) for |=: ‘dict’ and ‘dict’ 原因:python3.9 支持对 ...
    99+
    2023-10-26
    python linux ubuntu
  • ubuntu18.04更新后无法进入系统怎么办
    ubuntu18.04更新后无法进入系统的解决方法。重启ubuntu18.04,在进入grub引导界面后,按E进入编辑页面。再页面中找到splash,其后按空格后输入“nomodeset”。输入后,按ctrl+x或F10保存后重新进入ubu...
    99+
    2024-04-02
  • 更新后Win10系统后开机变得很慢如何解决
    这篇文章将为大家详细讲解有关更新后Win10系统后开机变得很慢如何解决,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。方法一按快捷键“win+R” 打开 运行窗口这时候输入“msconfig”...
    99+
    2023-06-07
  • win7更新程序完后总是提示重新启动系统
    有时候想说win7是一个细心的系统,有时候想说win7是一个麻烦的系统,总是没完没了的提示,尤其是每次更新程序完后总是提示重新启动系统,相当厌烦,win7何时才能休停一下这提示呢 1、打开开始菜单,选择“运行...
    99+
    2023-06-05
    win7 提示 重新启动 程序 系统 更新
  • Win10系统更新后开机黑屏怎么解决
    这篇文章主要介绍“Win10系统更新后开机黑屏怎么解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Win10系统更新后开机黑屏怎么解决”文章能帮助大家解决问题。Win10系统更新后开机黑屏解决方法...
    99+
    2023-07-01
  • Win10一周年更新值得更新吗?Win10系统一周年更新升级后到底如何?
      虽然微软官方已经宣布其将于8月2日开始全球推送Win10一周年更新,然而微软高管在不同场合也表示,这次的推送范围是全球同步,但是各地区Win10设备接收到推送更新信息的时间还是会受到用户所在时区和微软公司制定的推送批...
    99+
    2023-05-21
    Win10一周年 Win10 一周年更新 Win10更新 升级win10
  • win10开机一直请稍后很久才进系统怎么解决
    这篇文章主要介绍“win10开机一直请稍后很久才进系统怎么解决”,在日常操作中,相信很多人在win10开机一直请稍后很久才进系统怎么解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”win10开机一直请稍后很...
    99+
    2023-06-30
  • 系统更新后电脑鼠标失灵怎么解决
    这篇文章主要介绍了系统更新后电脑鼠标失灵怎么解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇系统更新后电脑鼠标失灵怎么解决文章都会有所收获,下面我们一起来看看吧。打开电脑,点击左下角的开始菜单,选择电源按钮,...
    99+
    2023-06-27
  • win10系统1909版本更新后蓝屏如何解决
    本篇内容介绍了“win10系统1909版本更新后蓝屏如何解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!方法一: 在win10系统桌面左下...
    99+
    2023-07-01
  • 如何关闭win10系统中更新后自动重启
    这篇文章给大家分享的是有关如何关闭win10系统中更新后自动重启的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、首先按快捷键“win+R”打开“运行”窗口,然后输入“regedit”命令后按回车键,即可打开“注...
    99+
    2023-06-28
  • 电脑系统更新后无法打字怎么解决
    如果电脑系统更新后无法打字,可以尝试以下几种解决方法:1. 检查键盘连接:确保键盘正确连接到电脑。如果是有线键盘,可以尝试重新插拔连...
    99+
    2023-10-18
    电脑
  • 如何更新openSUSE系统
    要更新openSUSE系统,您可以通过以下步骤来进行: 打开终端窗口:您可以通过在应用程序菜单中搜索终端来打开终端窗口。 运...
    99+
    2024-04-02
  • ubuntu更新内核后进不去系统怎么解决
    如果更新Ubuntu内核后无法进入系统,可以尝试以下方法解决问题:1. 选择较早的内核版本:在启动时,选择高级选项或高级选单,然后选...
    99+
    2023-08-11
    ubuntu
  • ubuntu系统如何更新
    这篇文章将为大家详细讲解有关ubuntu系统如何更新,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。用ubuntu那么久有点问题总想着能不能更新下解决,那么ubuntu怎么做系统更新呢?我们通常使用这两种方...
    99+
    2023-06-13
  • 怎么更新Fedora系统
    更新Fedora系统可以通过以下步骤进行: 打开终端:点击应用程序菜单,搜索终端并打开。 输入以下命令来更新软件包列表: ...
    99+
    2024-03-13
    Fedora
  • 更新Win10系统后声音查询异常如何解决
    更新Win10系统后声音查询异常如何解决?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。方法步骤打开设备,右键单击桌面右下角的“音量”图标,并选取“打开音量合成器...
    99+
    2023-06-07
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作