python3.x编码解码unicode字符串

1 python3.x编码解码unicode字符串

python的ASCII码范围为0,127,非ASCII码范围大于127.

通过str.encode(encoding)和bytes(str,encoding)根据编码名将字符串编码为原始字节。

通过bytes.decode(encoding)和str(bytes,encoding)根据编码名将原始字节解码为字符串。

gbk编码中,1个汉字表示2个字节,utf-8编码中,1个汉字表示3个字节。

1个字节用2位16进制表示。编码和解码必须送编码名encoding。

'\xNN'为两个十六进制,表示1个字节,

'\uNNNN'为unicode转义,表示四个十六进制位,编码1个2字节(16位)字符码,

'\UNNNNNNNN'为unicode转义,表示八个十六进制位,编码1个4字节(32位)字符码,

2个16进制对应1个字节。

注意,2字节用小u(\u),4字节用大U(\U)。

1.1 编码ASCII文本

ASCII文本编码是一种Unicode,存储为表示字符的字节值的一个序列。

ASCII码范围0-127.通过编码后,在字符前加b或B,打印值和字符相同。

python 复制代码
>>> ord('a')
97
>>> chr(97)
'a'
>>> s='abc'
>>> s
'abc'
>>> len(s)
3
>>> [ord(c) for c in s]
[97, 98, 99]
>>> s.encode('ascii')
b'abc'
>>> s.encode('gbk')
b'abc'
>>> s.encode('utf-8')
b'abc'
>>> b_asc=s.encode('ascii')
>>> b_gbk=s.encode('gbk')
>>> b_utf8=s.encode('utf-8')
>>> list(map(list,(b_asc,b_gbk,b_utf8)))
[[97, 98, 99], [97, 98, 99], [97, 98, 99]]

1.2 编码非ASCII文本

编码非ASCII字符(编码值大于127),需用十六进制或Unicode转义。

十六进制转义用于单字节,Unicode用于两个或四个字节。

示例

python 复制代码
>>> a,b=0xa5,0xa9
>>> a,b
(165, 169)
>>> hex(a),hex(b)
('0xa5', '0xa9')
>>> chr(a),chr(b)
('¥', '©')
# \xNN 十六进制单字节格式
>>> s1='\xa5\xa9'
# \uNNNN Unicode 双字节格式
>>> s2='\u00a5\u00a9'
>>> s1,s2
('¥©', '¥©')
>>> len(s1),len(s2)
(2, 2)
# \UNNNNNNNN Unicode 四字节格式
>>> s3='\U000000a5'
>>> s3
'¥'

1.3 编码和解码非ASCII文本

描述

# 项目 描述
1 \xNN 2位16进制,表示单字节,用\x转义,表示ASCII文本的unicode
2 \uNNNN 4位16进制,表示双字节,用\u转义,表示非ASCII文本的unicode
3 \UNNNNNNNN 8位16进制,表示四字节,用\U转义,表示非ASCII文本的unicode
4 单字节 1个字节2位16进制
5 ASCII编码 范围0-127
6 非ASCII编码 范围大于127
7 gbk编码 1个汉字2个字节,1个字节2位16进制
8 utf-8编码 1个汉字3个字节,1个字节2位16进制
9 unicode文本 python3.x的字符串str为unicode文本
10 ord© 获取字符c的unicode编码,为整数
11 hex(i) 获取整数i的16进制
12 hex(ord©) 获取字符c的unicode编码的16进制,用\u转义
13 str.encode(encoding) 根据编码名encoding将字符串str编码为原始字节,返回bytes类型数据,b或B开头
14 bytes.decode(encoding) 根据编码名encoding将原始字节解码为字符串,返回str类型数据
15 bytes(str,encoding) 根据编码名encoding将字符串str编码为原始字节,返回bytes类型数据,b或B开头
16 str(bytes,encoding) 根据编码名encoding将原始字节解码为字符串,返回str类型数据

示例

python 复制代码
>>> c1,c2='梯','阅'
# \xNN 16进制单字节, \uNNNN 16进制双字节 , \UNNNNNNNN 16进制四字节
>>> c1_hexstr,c2_hexstr=hex(ord(c1)),hex(ord(c2))
# ord(c)获取c的unicode值,通过hex(i)获取unicode值的16进制
>>> c1_hexstr,c2_hexstr
('0x68af', '0x9605')
# \uNNNN 四位16进制表示的2个字节,1个汉字为2个字节的unicode
# 每个字节的unicode 用\u 转义 原始字节
>>> c1c2='\u68af\u9605'
>>> c1c2
'梯阅'
>>> len(c1c2)
2
# ASCII 范围为[0,127]
>>> c1c2.encode('ascii')
Traceback (most recent call last):
  File "<pyshell#82>", line 1, in <module>
    c1c2.encode('ascii')
UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-1: ordinal not in range(128)
# 通过 编码名 gbk 的码表编码, 1个 汉字为2个字节 ,1个字节为2位16进制
# str.encode(encoding) 根据编码名 将字符串编码为原始字节
>>> c1c2.encode('gbk')
b'\xcc\xdd\xd4\xc4'
>>> '梯阅'.encode('gbk')
b'\xcc\xdd\xd4\xc4'
# 通过 编码名 utf-8 的码表编码,1个 汉字为 3个字节,1个字节为2位16进制
>>> c1c2.encode('utf-8')
b'\xe6\xa2\xaf\xe9\x98\x85'
>>> type(c1c2.encode('utf-8'))
<class 'bytes'>
>>> bytes(c1c2,encoding='utf-8')
b'\xe6\xa2\xaf\xe9\x98\x85'
>>> gbk_c1c2_raw=b'\xcc\xdd\xd4\xc4'
>>> utf8_c1c2_raw=b'\xe6\xa2\xaf\xe9\x98\x85'
>>> len(gbk_c1c2_raw),len(utf8_c1c2_raw)
(4, 6)
# bytes.decode(encoding) 根据编码名 将原始字节解码为字符串
>>> gbk_c1c2_dcd=gbk_c1c2_raw.decode('gbk')
>>> utf8_c1c2_dcd=utf8_c1c2_raw.decode('utf-8')
>>> gbk_c1c2_dcd,utf8_c1c2_dcd
('梯阅', '梯阅')
>>> str(gbk_c1c2_raw,encoding='gbk')
'梯阅'
>>> len(gbk_c1c2_dcd),len(utf8_c1c2_dcd)
(2, 2)
相关推荐
不知名的老吴2 小时前
Lambda表达式与新的Streams API相结合
开发语言·python
weelinking8 小时前
【产品】12_接入数据库——让数据永久保存
jvm·数据库·python·react.js·数据挖掘·前端框架·产品经理
程序大视界9 小时前
【Python系列课程】Python正则表达式(下):环视、命名分组与日志实战
开发语言·python·正则表达式
TickDB9 小时前
美股行情 API 接入避坑:REST 快照、WebSocket 推送、盘前盘后数据的边界
人工智能·python·websocket·行情数据 api
枫叶v.9 小时前
Agent 分层存储架构设计:从记忆方法到中间件选型
开发语言·python
水兵没月10 小时前
逆向实战小记——某ToB商城网站分析学习
python·网络爬虫
程序员小远10 小时前
Python自动化测试框架及工具详解
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
sleven fung11 小时前
MinerU与BabelDOC与KTransformers与OpenAI API库
开发语言·python·ai·langchain
小毛驴85011 小时前
spring-boot-maven-plugin,maven-compiler-plugin 功能对比
java·python·maven
萤萤七悬11 小时前
【Python笔记】AI帮实现CLI工具-使用argparse.ArgumentParser接收命令参数
开发语言·笔记·python