我有一个数据框
df=
A B C
1 2 55
0 44 0
0 0 0
Run Code Online (Sandbox Code Playgroud)
如果值 > 0,我想将值更改为 1。
这是正确的方法:df.loc[df>0,]=1
to give:
A B C
1 1 1
0 1 0
0 0 0
Run Code Online (Sandbox Code Playgroud)
使用clip_upper:
df = df.clip_upper(1)
print (df)
A B C
0 1 1 1
1 0 1 0
2 0 0 0
Run Code Online (Sandbox Code Playgroud)
Numpy 替代方案:
df = pd.DataFrame(np.clip(df.values, a_min=0, a_max=1),
index=df.index,
columns=df.columns)
print (df)
A B C
0 1 1 1
1 0 1 0
2 0 0 0
Run Code Online (Sandbox Code Playgroud)
如果没有负整数值,则解决方案 - 通过ge( >=)比较并将掩码转换为整数:
print (df.ge(1))
A B C
0 True True True
1 False True False
2 False False False
df = df.ge(1).astype(int)
print (df)
A B C
0 1 1 1
1 0 1 0
2 0 0 0
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6797 次 |
| 最近记录: |