1

我想替换数据中的一整行,前提是该行中的一列满足条件。即红色是数据框

['1' 0.0 ' P']
['2' 0.0 ' S']
['3' 64  ' M']
['4' 70  ' M']



red=red.replace(to_replace=' M', value=0)

返回结果:

['1' 0.0 ' P']
['2' 0.0 ' S']
['3' 64  0]
['4' 70  0]

但我希望它返回:

['1' 0.0 ' P']
['2' 0.0 ' S']
['3' 0  0]
['4' 0  0]
4

1 回答 1

6

用于loc过滤掉要归零的DataFrame部分,然后为其赋值。下面,它选择c列值所在的所有行,'M'并将所有列从bc,并将此选择的值设置为0

df = pd.DataFrame([['1', 0.0, 'P'],
    ...: ['2', 0.0, 'S'],
    ...: ['3', 64,  'M'],
    ...: ['4', 70,  'M'],], columns=['a', 'b', 'c'])

df.loc[df['c']=='M','b':'c'] = 0

df
Out[54]: 
   a  b  c
0  1  0  P
1  2  0  S
2  3  0  0
3  4  0  0
于 2013-10-17T12:38:45.727 回答