gpt4 book ai didi

python - Pandas 中 DataFrame 列表的按行映射

转载 作者:行者123 更新时间:2023-12-01 08:58:19 25 4
gpt4 key购买 nike

我在 Python (3) 中有一个带有 bool 值的数据框列表,我想要列表的逐行 AND,但我不知道该怎么做:

d1 = pd.DataFrame({'v' : [True, True, True, True]})
d2 = pd.DataFrame({'v' : [False, True, True, True]})
d3 = pd.DataFrame({'v' : [False, True, False, True]})

dfs = [d1, d2, d3]

我想要的是一个值为 [False, True, False, True] 的数据框。我尝试过将 lambda 与 apply 一起使用,但我不知道对于我不知道其大小的值列表是否可行。而且我没有看到用于在值列表或 DataFrame 列上应用二元运算符的 foldLeft (或类似选项)。

有什么想法吗?

最佳答案

使用concatDataFrame.all检查每行是否所有 True:

print (pd.concat(dfs, axis=1))
v v v
0 True False False
1 True True True
2 True True False
3 True True True

print (pd.concat(dfs, axis=1).all(axis=1))
0 False
1 True
2 False
3 True
dtype: bool

或者np.logical_and.reduce具有列表理解:

print (np.logical_and.reduce([x['v'] for x in dfs]))
[False True False True]

关于python - Pandas 中 DataFrame 列表的按行映射,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52647723/

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