实际工作中,我们有时需要将单字符串转对应的 ASCII 数值 ,怎么办呢?Python内置函数 ord() 提供了解决方法。下面我们一起来学习一下。
ord() 函数
定义:
ord() 函数是 chr() 函数(对于8位的ASCII字符串)或 unichr() 函数(对于Unicode对象)的配对函数,它以一个字符(长度为1的字符串)作为参数,返回对应的 ASCII 数值,或者 Unicode 数值,如果所给的 Unicode 字符超出了你的 Python 定义范围,则会引发一个 TypeError 的异常。
语法:ord ( c )
参数 :c是一个长度为1的单字符,返回值为对应的ASCII 十进制整数。
例如求数字 0-9 的ASCII 数值:
str = "0123456789"
for i in str:
print(i,"的ASCII值为:",ord(i))
#Output
# 0 的ASCII值为: 48
# 1 的ASCII值为: 49
# 2 的ASCII值为: 50
# 3 的ASCII值为: 51
# 4 的ASCII值为: 52
# 5 的ASCII值为: 53
# 6 的ASCII值为: 54
# 7 的ASCII值为: 55
# 8 的ASCII值为: 56
# 9 的ASCII值为: 57
因此我们得出字符’ 0 ’ ~ ’ 9 '的ASCII 为 48 ~ 57 。
同理,我们求出a~z的ASCII 数值。( 97 ~122)
str = "az"
for i in str:
print(i,"的ASCII值为:",ord(i))
#Output
#a 的ASCII值为: 97
#z 的ASCII值为: 122
最后我们已一道力扣真题详细体会ord函数的作用:
题面:8. 字符串转换整数 (atoi)
请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数)。
函数 myAtoi(string s) 的算法如下:
读入字符串并丢弃无用的前导空格
检查下一个字符(假设还未到字符末尾)为正还是负号,读取该字符(如果有)。 确定最终结果是负数还是正数。 如果两者都不存在,则假定结果为正。
读入下一个字符,直到到达下一个非数字字符或到达输入的结尾。字符串的其余部分将被忽略。
将前面步骤读入的这些数字转换为整数(即,“123” -> 123, “0032” -> 32)。如果没有读入数字,则整数为 0 。必要时更改符号(从步骤 2 开始)。
如果整数数超过 32 位有符号整数范围 [−231, 231 − 1] ,需要截断这个整数,使其保持在这个范围内。具体来说,小于 −231 的整数应该被固定为 −231 ,大于 231 − 1 的整数应该被固定为 231 − 1 。
返回整数作为最终结果。
注意:
本题中的空白字符只包括空格字符 ’ ’ 。
除前导空格或数字后的其余字符串外,请勿忽略任何其他字符。
思路:此题要考虑很多限制条件,如两边的边界,正负号,首次匹配不是数字等情况,我们需要一一判断并筛选。首先定义边界条件,MIN = -2 ** 31、MAX = 2 ** 31 - 1,其次用到了s.lstrip()去掉了左边的空格,如果要去掉两边空格是s.strip()。下来就是一些判断,可以详细参考代码,然后是最重要的部分,对数字部分的识别和选择,用上了我们刚学习的ord()函数:48 <= ord(s[i]) <= 57,这句代码就是将字符转化为ASCII,若为数字0~9,则保存否则退出循环。真的是太好用了!
此题还有一种思路是是使用正则表达式,这里不详细说明,仅给出代码,了解详情请点击此链接。
代码实现(ord函数):
#str = " -43423423 -fd 14646 455 "
MIN = -2 ** 31
MAX = 2 ** 31 - 1
ans = ''
s = s.lstrip() # 去除左边空格
for i in range(len(s)):
if s[i] == '+' and ans == '':
ans += '+'
elif s[i] == '-' and ans == '':
ans += '-'
elif 48 <= ord(s[i]) <= 57:
ans += s[i]
else:
break
if ans == '-' or ans == '+' or ans == '':
return 0
ans = int(ans)
if ans > MAX:
return MAX
elif ans < MIN:
return MIN
else:
return ans
代码实现(正则表达式):
import re
#str = " -43423423 -fd 14646 455 "
INT_MAX = 2147483647
INT_MIN = -2147483648
str = str.lstrip() # 清除左边多余的空格
num_re = re.compile(r'^[\+\-]?\d+') # 设置正则规则
num = num_re.findall(str) # 查找匹配的内容
num = int(*num) # 由于返回的是个列表,解包并且转换成整数
print(max(min(num, INT_MAX), INT_MIN)) # 返回值