相关疑难解决方法(0)

numpy数组的条件运算

我是NumPy的新手,我遇到了在numpy数组上运行一些条件语句的问题.假设我有3个numpy数组,如下所示:

A:

[[0, 4, 4, 2],
 [1, 3, 0, 2],
 [3, 2, 4, 4]]
Run Code Online (Sandbox Code Playgroud)

b:

[[6, 9, 8, 6],
 [7, 7, 9, 6],
 [8, 6, 5, 7]]
Run Code Online (Sandbox Code Playgroud)

而且,c:

[[0, 0, 0, 0],
 [0, 0, 0, 0],
 [0, 0, 0, 0]]
Run Code Online (Sandbox Code Playgroud)

我有一个a和b的条件语句,其中我想使用b的值(如果满足a和b的条件)来计算c的值:

c[(a > 3) & (b > 8)]+=b*2
Run Code Online (Sandbox Code Playgroud)

我收到一个错误说:

Traceback (most recent call last):
  File "<interactive input>", line 1, in <module>
ValueError: non-broadcastable output operand with shape (1,) doesn't match the broadcast shape (3,4)
Run Code Online (Sandbox Code Playgroud)

知道我怎么能做到这一点?

我想c的输出看起来如下:

[[0, 18, 0, 0], …
Run Code Online (Sandbox Code Playgroud)

python arrays conditional numpy

5
推荐指数
2
解决办法
1万
查看次数

修改Pandas DataFrame中的标记值

我有一个这样的数据框:

df = pd.DataFrame()
df['vals'] = [1,2,3,4,5]
df['flagged'] = ['N','Y','N','N','Y']
Run Code Online (Sandbox Code Playgroud)

修改值列(标志为“ Y”)的最惯用的方式是什么。例如,将5加到每个标记的值,这样df['vals'] == [1,7,3,4,10]

python pandas

1
推荐指数
1
解决办法
36
查看次数

pandas,根据其他列替换数据框中的值

我有一个如下所示的数据框,

df = pd.Dataframe({'Col1' : pd.Series(['Abc','Cde','Efg','Abc'], index=['a', 'b', 'c','d']),
 'Col2' : pd.Series([10, 20, 30, 40], index=['a', 'b', 'c', 'd']),
 'Col3' : pd.Series([1, 2., 3., 4.], index=['a', 'b', 'c', 'd'])})
Run Code Online (Sandbox Code Playgroud)

根据Col1中列值的值,我想用Col2替换Col3值,

在这种情况下,Col1 值是“Abc”,我想用 Col2 值更新 Col3 值,期望输出如下

pd.Dataframe({'Col1' : pd.Series(['Abc','Cde','Efg','Abc'], index=['a', 'b', 'c','d']),
 'Col2' : pd.Series([10, 20, 30, 40], index=['a', 'b', 'c', 'd']),
 'Col3' : pd.Series([10, 2., 3., 40], index=['a', 'b', 'c', 'd'])})
Run Code Online (Sandbox Code Playgroud)

通过过滤器尝试过,这不是通用的,所以任何正确的方法都可以做同样的事情!

python dataframe pandas

0
推荐指数
1
解决办法
609
查看次数

标签 统计

python ×3

pandas ×2

arrays ×1

conditional ×1

dataframe ×1

numpy ×1