[英]Creating new list names during iteration to .append() elements
我正在尝试添加元素的迭代过程中创建新的list_names。
# input
df = pd.DataFrame({"R1": [8,2,3], "R2": [-21,-24,4], "R3": [-9,46,6]})
# desired Output
list1 = df.values[0].tolist()
print(list1)
list2 = df.values[1].tolist()
print(list2)
list3 = df.values[2].tolist()
print(list3)
# failed attempt
for i in range(3):
print(f'{"list"}{i}') = df.values[i].tolist()
您可以在整个数据框架上工作而无需迭代。 一次访问底层数组并将其转换为列表列表。
import pandas as pd
df = pd.DataFrame({"R1": [8,2,3], "R2": [-21,-24,4], "R3": [-9,46,6]})
#out = df.to_numpy().tolist() for pandas >0.24
out = df.values.tolist()
print(out)
print(out[0])
print(out[1])
print(out[2])
输出:
[[8, -21, -9], [2, -24, 46], [3, 4, 6]]
[8, -21, -9]
[2, -24, 46]
[3, 4, 6]
通过这种方式,您可以将out
变量用作所需的所有单个列表的集合。
如果您想改用字典,也可以如下创建:
out_dict = {f"list{i}":lst for i, lst in enumerate(out, start=1)}
#Output:
{'list1': [8, -21, -9], 'list2': [2, -24, 46], 'list3': [3, 4, 6]}
print(out_dict['list1'])
print(out_dict['list2'])
print(out_dict['list3'])
在列表方法和字典方法之间,您应该能够涵盖您真正需要的所有用例。 尝试动态制作可变数量的变量通常是一个坏主意。 相关阅读
for i in range(3):
print('list{} = {}'.format(i, df.loc[i].values.tolist()))
输出量
list0 = [8, -21, -9]
list1 = [2, -24, 46]
list2 = [3, 4, 6]
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.