【问题标题】:Python Error: AttributeError: 'NoneType' object has no attribute 'to_excel'Python 错误:AttributeError:“NoneType”对象没有属性“to_excel”
【发布时间】:2020-05-07 16:50:37
【问题描述】:

我正在尝试合并一个目录中的所有文件并将合并的文件保存到另一个目录中。 我正在使用 Python 3.8。 当我运行代码时,我得到以下带有 AttributeError 的信息:

c:\test\Upload test\Book1.xlsx
c:\test\Upload test\Book2.xlsx
c:\test\Upload test\Book3.xlsx
Traceback (most recent call last):
File "C:/Python/PythonDev/combine.py", line 104, in <module>
newdf.to_excel(writer,"All")
AttributeError: 'NoneType' object has no attribute 'to_excel'

代码:

import pandas as pd
import globe
filelist = glob.glob(r'c:\test\Upload test\*.xlsx')
file1 = "*.*"
for i in  filelist:
    file2 = pd.read_excel(i)
    file2['FileName'] = i
    file1 = ['newdf']
    newdf = file1.append(file2)
    print (i)
writer = pd.ExcelWriter(r'c:\test\Uploaded\uploadfile.xlsx', engine= 'xlsxwriter')
newdf.to_excel(writer,"All")
writer.save()

【问题讨论】:

  • 抱歉错字。问题应该是“我正在尝试合并一个目录中的所有文件,然后将合并的文件保存到另一个目录中。”
  • 追加不返回任何东西...

标签: python attributeerror nonetype


【解决方案1】:

追加不会返回任何东西...

试试这样的:

import pandas as pd
import glob

raw_files = glob.glob(r'c:\test\Upload test\*.xlsx')

pd_files = pd.DataFrame()

for file in raw_files:
    pd_files.append(pd.read_excel(file))

pd_files.to_excel("c:\test\Uploaded\uploadfile.xlsx")

【讨论】:

  • 谢谢,已经消除了错误,但是保存的文件(uploadfile.xlsx)是空的。所以代码正在读取文件并生成一个空文件,但数据应该附加到这个新文件中。我认为 pd.files.a[[end 应该解决这个问题?
  • @user8763797:我做了一些更改,如果该代码有效,请 lmk...
猜你喜欢
  • 2022-08-12
  • 2019-07-18
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2022-07-20
  • 2023-03-03
  • 1970-01-01
相关资源
最近更新 更多