Warum kann ich nicht „Speichern unter“ eine Excel-Datei von meinem Python-Code?

StackOverflow https://stackoverflow.com/questions/3730428

  •  03-10-2019
  •  | 
  •  

Frage

Ich habe eine Python ExcelDocument Klasse, die zum Lesen / Schreiben / Formatieren von Excel-Dateien grundlegende Komfortmethoden bietet, und ich bin in scheinbar einfachen Python-Code einen seltsamen Fehler. Ich habe eine speichern und saveAs Methode:

def save(self):
   ''' Save the file '''
   self.workbook.Save()

def saveAs(self, newFileName):
   ''' Save the file as a new file with a different name '''
   self.workbook.SaveAs(newFileName)

Die Save-Methode funktioniert perfekt, aber wenn ich versuche, die saveAs Methode aufrufen - myExcelObject.saveAs("C:/test.xlsx") - ich folgende Fehlermeldung erhalten:

Traceback (most recent call last):
  File "C:\workspace\Utilities\src\util\excel.py", line 201, in <module>
    excel.saveAs("C:/test.xlx")
  File "C:\workspace\Utilities\src\util\excel.py", line 185, in saveAs
    self.workbook.SaveAs(newFileName)
  File "<COMObject Open>", line 7, in SaveAs
pywintypes.com_error: (-2147352567, 'Exception occurred.', (0, u'Microsoft Office Excel', u"Microsoft Office Excel cannot access the file 'C:\\//8CBD2000'. There are several possible reasons:\n\n\u2022 The file name or path does not exist.\n\u2022 The file is being used by another program.\n\u2022 The workbook you are trying to save has the same name as a currently open workbook.", u'C:\\Program Files\\Microsoft Office\\Office12\\1033\\XLMAIN11.CHM', 0, -2146827284), None)

Kann mir jemand erklären, was passiert ist?

War es hilfreich?

Lösung

Ich habe festgestellt (die harte Art und Weise), dass SaveAs nicht unterstützt slash /.
Versuchen Sie saveAs("C:\\test.xlx") statt.

Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top