gpt4 book ai didi

python - 根据 Pandas 中多列中的值选择数据

转载 作者:太空宇宙 更新时间:2023-11-04 10:25:06 24 4
gpt4 key购买 nike

我有以下 DataFrame,我需要分别在 [f1,f2,f3,f4,f5] 字段中选择具有 [1,2,3,4,5] 的数据。

ID  f1  f2  f3  f4  f5
1 1 2 3 4 5
2 2 3 4 5 6
3 1 2 3 4 5
4 5 4 2 3 4


df = DataFrame(numpy.array([[1, 1, 2, 3, 4, 5],
[2, 2, 3, 4, 5, 6],
[3, 1, 2, 3, 4, 5],
[4, 5, 4, 2, 3, 4]], dtype=int64),
columns = ['ID','f1','f2','f3','f4','f5'])

一个明显的方法是执行以下操作:

df[(df['f1'] == 1) & (df['f2'] == 2) & (df['f3'] == 3) & (df['f4'] == 4) & (df['f5'] == 5)]

有什么简洁的方法可以做到这一点吗?我需要多次执行此操作,并且某些其他 DataFrame 的字段名称可能不同。

最佳答案

一个稍微简单的方法可能是:

>>> df[(df.loc[:, 'f1':'f5'] == np.arange(1, 6)).all(1)]
ID f1 f2 f3 f4 f5
0 1 1 2 3 4 5
2 3 1 2 3 4 5

此处 df.loc[:, 'f1':'f5'] 选择列,并测试(按行)这些列是否与数组 [1, 2 , 3, 4, 5]

关于python - 根据 Pandas 中多列中的值选择数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29832090/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com