Windows下Python字符串编码问题

Python语言实际上有三种字符串,通常意义的字符串(str),Unicode字符串(unicode)和抽象类basestring,其中basestring不可实例化。
在Windows系统下的CPython解释器输入代码:

>>> st1 = '中文'
>>> st1
'\xd6\xd0\xce\xc4'
>>> type(st1)
<type 'str'>
>>> st2 = st1.decode('gbk')
>>> st2
u'\u4e2d\u6587'
>>> type(st2)
<type 'unicode'>
>>> st3 = st2.encode('utf-8')
>>> st3
'\xe4\xb8\xad\xe6\x96\x87'
>>> type(st3)
<type 'str'>
>>> st4 = st2.encode('gbk')
>>> st4
'\xd6\xd0\xce\xc4'
>>> type(st4)
<type 'str'>

如果在代码中加入一句:

>>> st5 = st1.decode('utf-8')

则会报错

从上面的代码和输出我们可以得到如下结论:
1、Windows命令行输入的默认中文编码格式是gbk,输入的中文字符串类型为str
2、使用decode函数可以将一个str类型的中文字符串转成unicode类型
3、使用encode函数可以将一个unicode类型的中文字符串转成str类型

所以我们一般在进行Python脚本编写的时候,需要在脚本的开头加上如下代码:

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

也可以导入模块sys,设置默认编码格式:

import sys
sys.setdefaultencoding('utf-8')

PS: Python版本为python2.7

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值