python - 如何在python中同时使用applymap、lambda和dataframe来过滤/修改dataframe?

标签 python function pandas lambda

所以我想弄清楚如何替换 pd.DataFrame 中的 NaN ..? 在示例中,我创建了 3x3 数据帧,在 df[1][2] = 'a' 中具有值,其余为 NaN

我的理解是我可以在 lambda 中使用 if 并在下面做一些事情。但是结果不是我所期望的,它覆盖了'a'。我仍然希望 'a' 保持原样,只更改为 'o' 其中 NaN ...任何建议将不胜感激.

enter image description here

df = pd.DataFrame(index=range(0,3),columns=range(0,3))
df[1][2] = 'a'
f = lambda x: 'o' if np.nan else x
df.applymap(f)

最佳答案

您可以使用 fillna 而不是使用 apply

df.fillna('o')

有关Working with missing data的更多信息.您还可以将 applypd.isnull() 一起使用,如@Psidom 答案中所述。但在这种情况下,您真的应该使用内置函数 fillna

关于python - 如何在python中同时使用applymap、lambda和dataframe来过滤/修改dataframe?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38236539/

相关文章:

Python:用整数扩展变量字符串

c++ - 从列表中删除回调函数?

pandas - 使用python pandas在合并的数据框中将整数变为小数

python - 使用一组子列分配新列

python - sqlalchemy 是否可以添加字段级别规则,即两个特定列不能同时为 None?

python - Django LFS 0.10 无默认管理员用户

javascript - 为什么在同一语句中调用时括号会保留它

python - 如何在Python中使用.loc创建一个不大于的条件

python - 用字符串周围的引号编写 csv (Python)

python - 分类变量 pandas