pandas
中的大多数操作都可以通过操作符链接(groupby
、aggregate
、apply
等)完成,但我发现筛选行的唯一方法是通过普通的括号索引
df_filtered = df[df['column'] == value]
这是没有吸引力的,因为它要求我在能够过滤变量值之前将df
赋值给变量。还有更像下面这样的吗?
df_filtered = df.mask(lambda x: x['column'] == value)
来自@lodagro的答案很好。我将通过将掩码函数推广为:
def mask(df, f):
return df[f(df)]
然后你可以做这样的事情:
df.mask(lambda x: x[0] < 0).mask(lambda x: x[1] > 0)
可以使用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')
我不完全确定您想要什么,您的最后一行代码也没有帮助,但无论如何:
“链接”过滤是通过“链接”布尔索引中的条件来完成的。
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消失), ,,,,和。