ord函数和chr函数

2019年10月14日 / 9次阅读 / Last Modified 2019年10月14日
内置函数

ord函数(order)返回一个字符对应的unicode编码,而chr函数(char)正好反过来,它返回一个unicode编码对应的字符。他们都是python内置函数。

为什么是unicode?因为unicode长度统一,都是2个byte,非常利于代码处理。UTF-8编码其实是一种压缩编码,字符长度不统一,适合存储和传输。(不管什么编码,ASCII符号对应的值都是一样的,英语是最佳计算机语言,不分国界,正如阿拉伯数字是最佳数字语言,也不分国界一样。)

>>> for c in '麦新杰的www.pynote.net':
...     print(c,ord(c),chr(ord(c)))
...
麦 40614 麦
新 26032 新
杰 26480 杰
的 30340 的
w 119 w
w 119 w
w 119 w
. 46 .
p 112 p
y 121 y
n 110 n
o 111 o
t 116 t
e 101 e
. 46 .
n 110 n
e 101 e
t 116 t

以上代码遍历一个字符串,一个个调用ord和chr函数并显示出来。

ord函数返回unicode编码,这样就可以将任意可以打出来的字符,都通过ord函数来寻找其对应的unicode值了。比如我们想找出所有中文标调符号的unicode值,只需要将所有中文标点符号输入ord函数即可。

chr函数的输入是unicode值,因此就存在一个有效范围的问题,官方解释有效范围是0到0x10ffff,否则会有ValueError抛出。既然unicode都是2个bytes,为什么有效范围的上限是3个bytes呢?我也不懂...

-- EOF --

本文链接:https://www.pynote.net/archives/1321

留言区

电子邮件地址不会被公开。 必填项已用*标注


前一篇:
后一篇:

More

麦新杰的Python笔记

Ctrl+D 收藏本页


©Copyright 麦新杰 Since 2019 Python笔记

go to top