我有一个来自MySQL查询的元组元组,如下所示:
T1 = (('13', '17', '18', '21', '32'),
('07', '11', '13', '14', '28'),
('01', '05', '06', '08', '15', '16'))
我想将所有字符串元素转换为整数,并将它们放回列表列表中:
T2 = [[13, 17, 18, 21, 32], [7, 11, 13, 14, 28], [1, 5, 6, 8, 15, 16]]
我试图用eval
来实现它,但还没有得到任何像样的结果。
发布于 2009-03-13 10:58:42
int()
是Python标准的内置函数,用于将字符串转换为整数值。使用包含数字作为参数的字符串调用它,它将返回转换为整数的数字:
>>> int("1") + 1
2
如果您知道列表T1的结构(它只包含一个级别的列表),那么您可以在Python3中做到这一点:
T2 = [list(map(int, x)) for x in T1]
在Python 2中:
T2 = [map(int, x) for x in T1]
发布于 2009-03-13 11:02:31
你可以通过列表理解来实现这一点:
T2 = [[int(column) for column in row] for row in T1]
内部列表理解([int(column) for column in row]
)从int
中的一系列int
-able对象(如十进制字符串)构建一个-able的row
。外部列表理解([... for row in T1])
)构建应用于T1
中每一项的内部列表理解结果的列表。
如果任何行包含不能由int
转换的对象,则代码片段将失败。如果您想处理包含非十进制字符串的行,则需要一个更智能的函数。
如果您知道行的结构,则可以使用对行的函数的调用来替换内部列表理解。例如:
T2 = [parse_a_row_of_T1(row) for row in T1]
发布于 2009-05-12 23:33:41
我更喜欢只使用理解列表:
[[int(y) for y in x] for x in T1]
https://stackoverflow.com/questions/642154
复制相似问题