Funkcja to_excel pand generuje nieoczekiwany błąd typu


13

Stworzyłem słownik ramki danych pand:

d[k] = pd.DataFrame(data=data[i])

Zakładam więc, że d[k]jest to poprawna ramka danych pand.

Następnie

for k in d.keys():
  d[k].to_excel (file_name)

Mam wtedy błąd:

TypeError: got invalid input value of type <class 'xml.etree.ElementTree.Element'>, expected string or Element

Używam Python 3.7, pandy 0.25.3.

Aktualizacja : jeśli zastąpić to_excelprzez to_csvkod działa doskonale.


1
co jest file_name? czy to jest struna?
Quang Hoang

Tak to jest. Po prostu coś w stylu'/data/myfile.xlsx'
mommomonthewind

co się stanie, jeśli spróbujesz d[k].to_excel(str(filename))?
Quang Hoang

Ten sam problem. Nie sądzę, że problem leży po stronie file_name. Sprawdziłem i jestem całkiem pewien, że jest to poprawna nazwa pliku.
mommomonthewind

Mam ten sam błąd przy użyciu Openpyxl: 3.0.2 pandy 0.25.3 Python 3.8.1 (tags / v3.8.1: 1b293b6, 18 grudnia 2019, 23:11:46) [MSC v.1916 64 bit (AMD64)] Usuwanie Openpyxl 3.0.2 i aktualizacja openpyxl do 3.0.3 naprawiły problem, jak zgłaszają inni. Dziękuję Ci. Dodam jeszcze jedną rzecz: błąd openpyxl 3.0.2 spowodował uszkodzenie pliku * .xlsx, do którego był dołączany, przez co stał się nieczytelny i niemożliwy do odzyskania przez program Excel.
user39678

Odpowiedzi:


Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.