如何自定义一个函数作用在dataframe的每一个值上

发布于 2022-09-07 15:41:43 字数 1364 浏览 18 评论 0

def hour_exceed(df):

i=df.values
if i is np.nan:
    return np.nan
elif i>200:
    return 1
elif i<200:
    return 0

dataframe

df15.head()
Out[21]:

              time  1036A  1037A  1040A  1041A  1051A  1053A  1054A  \

0 2015-01-01 00:00:00 NaN NaN NaN NaN NaN NaN NaN
1 2015-01-01 01:00:00 NaN NaN NaN NaN NaN NaN NaN
2 2015-01-01 02:00:00 NaN NaN NaN NaN NaN NaN NaN
3 2015-01-01 03:00:00 NaN NaN NaN NaN NaN NaN NaN
4 2015-01-01 04:00:00 NaN NaN NaN NaN NaN NaN NaN

1057A 1062A ... 2593A 2600A 2643A 2654A 2655A 2657A 2667A \
0 NaN NaN ... NaN 32.0 NaN 9.0 9.0 3.0 8.0
1 NaN NaN ... NaN 33.0 NaN 9.0 8.0 3.0 6.0
2 NaN NaN ... NaN 23.0 NaN 8.0 8.0 2.0 5.0
3 NaN NaN ... NaN NaN NaN NaN NaN NaN NaN
4 NaN NaN ... NaN 52.0 NaN 7.0 4.0 1.0 6.0

2688A 2689A 2708A
0 9.0 3.0 NaN
1 8.0 2.0 NaN
2 11.0 4.0 NaN
3 NaN NaN NaN
4 6.0 5.0 NaN
如何定义一个自定义函数作用在dataframe的每一个值上

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

隐诗 2022-09-14 15:41:43

直接用df[df<=200]=0;df[df>200]=1就好了

浮萍、无处依 2022-09-14 15:41:43

跟怎么定义函数没关系,调用df.applymap()

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文