Python 字符串转ASCII码最优方法 ------ ord()

实际工作中,我们有时需要将单字符串转对应的 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))  # 返回值

猜你喜欢

转载自blog.csdn.net/chenjh027/article/details/128111688