在 for 循环中追加生成的熊猫数据框

我正在用 for 循环访问一系列 Excel 文件。然后我将 Excel 文件中的数据读取到一个熊猫数据框中。我不知道如何将这些数据框附加在一起,然后将数据框(现在包含来自所有文件的数据)保存为一个新的 Excel 文件。

我试过这么做:

for infile in glob.glob("*.xlsx"):
data = pandas.read_excel(infile)
appended_data = pandas.DataFrame.append(data) # requires at least two arguments
appended_data.to_excel("appended.xlsx")

谢谢!

308973 次浏览

使用 pd.concat将 DataFrame 列表合并到单个大 DataFrame 中。

appended_data = []
for infile in glob.glob("*.xlsx"):
data = pandas.read_excel(infile)
# store DataFrame in list
appended_data.append(data)
# see pd.concat documentation for more info
appended_data = pd.concat(appended_data)
# write DataFrame to an excel sheet
appended_data.to_excel('appended.xlsx')

你可以试试这个。

data_you_need=pd.DataFrame()
for infile in glob.glob("*.xlsx"):
data = pandas.read_excel(infile)
data_you_need=data_you_need.append(data,ignore_index=True)

希望能帮上忙。

不推荐使用 DataFrame.append ()和 Series.append () ,将在以后的版本中删除它们。