当前位置: 首页 > 知识库问答 >
问题:

pandas:使用运算符链接筛选数据帧的行

华涵意
2023-03-14

pandas中的大多数操作都可以通过操作符链接(groupbyaggregateapply等)完成,但我发现筛选行的唯一方法是通过普通的括号索引

df_filtered = df[df['column'] == value]

这是没有吸引力的,因为它要求我在能够过滤变量值之前将df赋值给变量。还有更像下面这样的吗?

df_filtered = df.mask(lambda x: x['column'] == value)

共有3个答案

莘欣怿
2023-03-14

来自@lodagro的答案很好。我将通过将掩码函数推广为:

def mask(df, f):
  return df[f(df)]

然后你可以做这样的事情:

df.mask(lambda x: x[0] < 0).mask(lambda x: x[1] > 0)
宗政英才
2023-03-14

可以使用Pandas查询链接筛选器:

df = pd.DataFrame(np.random.randn(30, 3), columns=['a','b','c'])
df_filtered = df.query('a > 0').query('0 < b < 2')

过滤器也可以组合在单个查询中:

df_filtered = df.query('a > 0 and 0 < b < 2')
徐隐水
2023-03-14

我不完全确定您想要什么,您的最后一行代码也没有帮助,但无论如何:

“链接”过滤是通过“链接”布尔索引中的条件来完成的。

In [96]: df
Out[96]:
   A  B  C  D
a  1  4  9  1
b  4  5  0  2
c  5  5  1  0
d  1  3  9  6

In [99]: df[(df.A == 1) & (df.D == 6)]
Out[99]:
   A  B  C  D
d  1  3  9  6

如果要链接方法,可以添加自己的掩码方法并使用该方法。

In [90]: def mask(df, key, value):
   ....:     return df[df[key] == value]
   ....:

In [92]: pandas.DataFrame.mask = mask

In [93]: df = pandas.DataFrame(np.random.randint(0, 10, (4,4)), index=list('abcd'), columns=list('ABCD'))

In [95]: df.ix['d','A'] = df.ix['a', 'A']

In [96]: df
Out[96]:
   A  B  C  D
a  1  4  9  1
b  4  5  0  2
c  5  5  1  0
d  1  3  9  6

In [97]: df.mask('A', 1)
Out[97]:
   A  B  C  D
a  1  4  9  1
d  1  3  9  6

In [98]: df.mask('A', 1).mask('D', 6)
Out[98]:
   A  B  C  D
d  1  3  9  6
 类似资料:
  • ValueError:序列的真值不明确。使用a.empty、a.bool()、a.item()、a.any()或a.all()。 所以我知道我没有正确使用or语句,有没有办法做到这一点?

  • 问题内容: 在大部分操作pandas可以与运营商链接(来完成,等),但我发现过滤行唯一方法是通过正常的托架索引 这没有吸引力,因为它要求我先分配df一个变量,然后才能根据其值进行过滤。还有以下内容吗? 问题答案: 我不确定你想要什么,最后一行代码也无济于事,但是无论如何: “链式”过滤是通过“链接”布尔索引中的条件来完成的。 如果要链接方法,可以添加自己的mask方法并使用该方法。

  • 我有两个数据帧。我需要用第二列中的平均值更新第一列中的一列,并按索引分组。这里是示例df1(col1是索引) df2(col1是索引) 我需要df2的col2(a=2,d=3)的平均值,并且只更新col3=X的行的df1 我试过这个 只有在我不使用loc的情况下,它才有效。 我试图得到的结果是df1(col1是索引)

  • 有没有一种方法可以将下面的两个数据流连接起来,这样: 我将有一个带有标题的新数据帧: 时间戳调整的关闭reportedEPS estimatedEPS 并且reportedEPS和estimatedEPS将根据以下值保持不变: 时间戳:1月1日至3月31日,4月1日至6月30日,7月1日至9月30日,10月1日至12月31日? 2个数据流: https://gyazo.com/38B50A3D7E

  • 这一组数据在进行groupby前已经完成筛选,但进行groupby聚合后的结果显示是利用未筛选的数据进行的聚合,就像下面的结果,在groupby前已经完成点击量非0过滤,但最后仍存在含0的资源,询问chatGPT给的方案是可能用索引前的数据进行的聚合,重置索引后仍无法解决,请教大牛是否遇到过类似的问题,虽然可以在聚合后重新进行filter过滤,但这个问题搞得很焦灼 代码源文本

  • 问题内容: python是否支持链接运算符,例如以下内容? 输出,一些文档引用会很好。 问题答案: 是。任何归类为比较的运算符都可以链接。从语言参考: 形式上,如果 a , b , c ,…, y , z 是表达式,而 op1 , op2 ,…, opN 是比较运算符,则等效于,除了每个表达式最多 可计算 一次。 比较运算符是,,,,,(很少使用同义词,在Python 3消失), ,,,,和。