一,常规的类型转换形式
str_data = "2" i = int(str_data, 10) str_data1 = "3" y = int(str_data1, 10) h = i + y print(h)结果:5
二,用map函数方法
str_data = "2" str_data1 = "3" a = list(map(int, str_data)) b = list(map(int, str_data1)) print(a[0] + b[0])结果:5
a=input()
a1,a2=map(int,a.split())
print(a1+a2)
输入2, 3
输出 5
三,eval()
a = "1" b = "2" print(eval(a) + eval(b))输出:3
eval和input函数在使用时需要非常小心,因为它们可以执行任意代码。如果不加限制地使用这些函数,攻击者可以通过注入恶意代码来执行系统命令、读取敏感文件等操作,从而造成严重的安全问题。
为了避免这种情况发生,应该尽可能避免使用eval和input函数,并且在必须使用时,要对输入进行严格的过滤和验证,确保只有合法的数据才能被执行。同时,还可以考虑使用更安全的替代方案,比如ast.literal_eval()函数来代替eval函数,或者使用Python的argparse模块来处理命令行参数,以避免直接调用系统命令。
四,用 ast.literal_eval()
ast.literal_eval()函数可以安全地将字符串转换为Python字面值表达式的值,例如字符串、数字、元组、列表、字典等。与eval不同,它只能处理一些简单的数据类型,并且不能执行任意代码。
使用ast.literal_eval()函数非常简单,只需要将要转换的字符串作为参数传递给该函数即可
import ast b = ast.literal_eval(input()) a = ast.literal_eval(input()) print(a + b)输入:3
2
输出: 5
在上面的示例中,将字符串传递给ast.literal_eval()函数,它会将其解析为一个int对象(因为字符串里面是一个int类型),并返回该对象。由于该函数只能处理一些简单的数据类型,因此如果传递的字符串无法被解析为合法的Python字面值表达式,该函数会抛出SyntaxError异常。