pandas 赋值代码运算速度优化,麻烦给一点意见,谢谢!

2020-11-02 13:32:23 +08:00
 yellowtail

'''

def fuc_compare(df, i):

try:
    if (df.loc[i+1].h > df.loc[i].h
         and df.loc[i+1].l > (df.loc[i].l + (df.loc[i].h - df.loc[i].l)/2)):

        df.loc['deal',i+1] = 1

        return
    if (df.loc[i+1].l < df.loc[i].l
         and df.loc[i+1].h < (df.loc[i].h - (df.loc[i].h - df.loc[i].l)/2)):
        df.loc['deal',i+1] = -1
        return
except:
    print('^^^^^^^^^error^^^^^^^^^^^^')
    return

i=0 while i < len(df_temp): fuc_compare(df_temp, i) i = i+1

'''

1161 次点击
所在节点    Python
2 条回复
yellowtail
2020-11-02 13:39:20 +08:00
不知道为啥代码格式总不对,还在上班( zf 编外摸鱼发帖),先不改了。。
yellowtail
2020-11-02 18:05:18 +08:00
其实也就是 pandas 中需要跨行取值的问题,如果用 for i,n in df.iterrows():会快一些但是不知道,程序运行时间主要是花在哪一块... 如果 loc 操作相对于 for 循环不算高时间消耗的话
也许有其他更好的办法..

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/720976

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX