将 Python pandas 数据框中的每个数字四舍五入到两位小数

新手上路,请多包涵

这有效 p_table.apply(pd.Series.round) 但是它没有小数位

文档说

import pandas as pd

Series.round(decimals=0, out=None)

我试过这个 p_table.apply(pd.Series.round(2)) 但得到这个错误:

 unbound method round() must be called with Series instance as first argument (got int instance instead)

如何将数据框中的所有元素四舍五入到小数点后两位?

[编辑]想通了。

 import numpy as np
np.round(p_table, decimals=2)

原文由 Tristan Forward 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 524
2 个回答
import numpy as np
np.round(p_table, decimals=2)

原文由 Tristan Forward 发布,翻译遵循 CC BY-SA 3.0 许可协议

由于 0.17.0 你可以做的版本 .round(n)

 df.round(2)
      0     1     2     3
0  0.06  0.67  0.77  0.71
1  0.80  0.56  0.97  0.15
2  0.03  0.59  0.11  0.95
3  0.33  0.19  0.46  0.92

df
          0         1         2         3
0  0.057116  0.669422  0.767117  0.708115
1  0.796867  0.557761  0.965837  0.147157
2  0.029647  0.593893  0.114066  0.950810
3  0.325707  0.193619  0.457812  0.920403

原文由 piroot 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题