加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

python – 为什么我的for循环覆盖而不是追加?

发布时间:2020-12-20 13:18:01 所属栏目:Python 来源:网络整理
导读:我有多个(25k).csv文件,我试图附加到HDFStore文件.它们都共享相同的标题.我使用下面的代码,但由于某种原因,每当我运行它时,数据帧不会附加所有文件,而只是列表中的最后一个文件. filenames = [] #list of .csv file paths that I've alredy populateddtypes=
我有多个(25k).csv文件,我试图附加到HDFStore文件.它们都共享相同的标题.我使用下面的代码,但由于某种原因,每当我运行它时,数据帧不会附加所有文件,而只是列表中的最后一个文件.

filenames = []  #list of .csv file paths that I've alredy populated
dtypes= {dict of datatypes}
store = pd.HDFStore('store.h5')
store.put('df',pd.read_csv(filenames[0],dtype=dtypes,parse_dates=
["date"])) #store one data frame

for f in filenames:
    try:
        temp_csv = pd.DataFrame()
        temp_csv = pd.read_csv(f,parse_dates=["trade_date"]) 
        store.append('df',temp_csv)
    except:
    pass

我已经尝试使用文件名列表的子集,但总是得到最后一个条目.出于某种原因,循环不会附加我的文件,而是每次都覆盖它.任何建议都会受到赞赏,因为这会让我感到疯狂. (python 3,windows)

解决方法

我认为问题与:

store.append(‘df’,temp_csv)

如果我正确理解你要做的事情,’df’应该改变每一次迭代,你现在只是覆盖它.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读