From 56628d57541a546c16857ff82015a9923cff48b6 Mon Sep 17 00:00:00 2001 From: Floke Date: Tue, 27 May 2025 05:50:16 +0000 Subject: [PATCH] bugfix --- list_generator.py | 102 ++++++++++++++++++---------------------------- 1 file changed, 40 insertions(+), 62 deletions(-) diff --git a/list_generator.py b/list_generator.py index a4aafda7..6c617919 100644 --- a/list_generator.py +++ b/list_generator.py @@ -4,21 +4,19 @@ import collections import os.path from google.oauth2 import service_account -from googleapiclient.discovery import build # discovery wird für das resource-Objekt der Lib benötigt +from googleapiclient.discovery import build from googleapiclient.errors import HttpError -# Importiere die neue Bibliothek - KORRIGIERTER IMPORT und KLASSENNAME -from gdoctableapppy.gdoctableapp import gdoctableapp # Klasse ist klein geschrieben +# Importiere die Bibliothek - korrigierter Import basierend auf Dateisystem +from gdoctableapppy.gdoctableapp import gdoctableapp # --- Konfiguration --- CSV_FILENAME = 'Namensliste.csv' GOOGLE_DOC_TITLE = f"Gruppenlisten_{datetime.now().strftime('%Y-%m-%d_%H-%M')}" TARGET_FOLDER_ID = "18DNQaH9zbcBzwhckJI-4Uah-WXTXg6bg" -# Diese werden nur für den einmaligen Infoblock verwendet EINRICHTUNG_INFO = "Kinderhaus St. Martin Neuching" FOTODATUM_INFO = "02. - 05.06.2025" - GRUPPENNAME_SUFFIX = "gruppe" SCOPES = [ @@ -42,8 +40,7 @@ def get_services_with_service_account(): return docs_service, drive_service def generate_tables_with_gdoctableapp(docs_api_service, document_id_to_fill): - # ... (CSV-Lesen, sorted_gruppen_namen, stand_zeit bleiben gleich) ... - kinder_nach_gruppen = collections.defaultdict(list) # Muss hier definiert werden + kinder_nach_gruppen = collections.defaultdict(list) try: with open(CSV_FILENAME, mode='r', encoding='utf-8-sig', newline='') as csvfile: reader = csv.DictReader(csvfile, delimiter=';') @@ -61,10 +58,19 @@ def generate_tables_with_gdoctableapp(docs_api_service, document_id_to_fill): try: resource_for_lib = {"docsService": docs_api_service, "documentId": document_id_to_fill} gtable_manager = gdoctableapp(resource_for_lib) + + # --- DEBUGGING: Methoden der Instanz anzeigen --- + print("\n--- Verfügbare Methoden/Attribute auf gtable_manager Objekt: ---") + print(dir(gtable_manager)) + print("--- Ende Debugging Ausgabe ---\n") + print("INFO: Skript wird nach dir() Ausgabe beendet für Debugging.") + exit() # Das Skript hier abbrechen, um die Ausgabe zu sehen + # --- ENDE DEBUGGING --- + except Exception as e_dta_init: print(f"Fehler bei der Initialisierung von gdoctableapp: {e_dta_init}"); return False - additional_requests_fallback = [] + additional_requests_fallback = [] # Nur für den unwahrscheinlichen Fall, dass wir es brauchen for i, gruppe_original in enumerate(sorted_gruppen_namen): kinder_liste = kinder_nach_gruppen[gruppe_original] @@ -78,51 +84,30 @@ def generate_tables_with_gdoctableapp(docs_api_service, document_id_to_fill): try: print(f"Versuche Tabelle für Gruppe '{gruppe_original}' mit gdoctableapp einzufügen...") - # KORREKTER METHODENNAME: create_table - res_table_obj = gtable_manager.create_table(values=table_values, index=None) + # HIER WÜRDEN DIE KORREKTEN METHODENAUFRUFE STEHEN, SOBALD WIR SIE KENNEN + # z.B. res_table_obj = gtable_manager.RICHTIGER_NAME_FUER_CREATE_TABLE(values=table_values, index=None) - # Die Doku für create_table sagt: - # "When this is used, the table is created to the last of body. And, this method returns the object including the created table object and the start and end indexes of the table." - # Das zurückgegebene Objekt sollte also `{"table_object": {...}, "startIndex": X, "endIndex": Y}` sein. - # Und table_object enthält `created_table` mit `startIndex` (was wir als `tableStartIndex` brauchen). + # ... (Logik für Fettformatierung mit korrekten Methodennamen) ... - # Laut der Doku zu `set_text_style_to_range` ist der Key im table_range Objekt `tableStartIndex` (großes S, kleines i). - if res_table_obj and "table_object" in res_table_obj and "created_table" in res_table_obj["table_object"]: - created_table_info = res_table_obj["table_object"]["created_table"] - table_start_idx_for_style = created_table_info.get("startIndex") # Dies ist der StartIndex des Tabellenobjekts selbst + # ... (Logik für Footer-Text mit korrekten Methodennamen) ... - if table_start_idx_for_style is not None: - header_range_for_style = { - "tableStartIndex": table_start_idx_for_style, # Korrekter Schlüsselname für die Methode - "rowIndex": 0, - "columnIndex": 0, - "rowSpan": 1, - "colSpan": 3 - } - text_style_bold = {"bold": True}; fields_bold = "bold" - # KORREKTER METHODENNAME: set_text_style_to_range - gtable_manager.set_text_style_to_range(text_style_bold, fields_bold, table_range=header_range_for_style) - print(f" Kopfzeile für Tabelle '{gruppe_original}' versucht fett zu formatieren.") - else: print(f" Konnte startIndex für Tabelle '{gruppe_original}' nicht erhalten für Formatierung.") - else: print(f" Unerwartete Antwort von create_table für Formatierung: {res_table_obj}") - - footer_lines_for_group = ["", f"{anzahl_kinder} angemeldete Kinder", "", "Dies ist die Liste der bereits angemeldeten Kinder. Bitte die Eltern der noch fehlenden", "Kinder an die Anmeldung erinnern.", "", f"Stand {stand_zeit}", ""] - full_footer_text_for_group = "\n".join(footer_lines_for_group) + "\n" - if full_footer_text_for_group.strip(): - # KORREKTER METHODENNAME: insert_text - gtable_manager.insert_text(text=full_footer_text_for_group, index=None) + pass # Platzhalter, da die eigentlichen Aufrufe noch unklar sind + except AttributeError as e_attr: + print(f"AttributeError bei Gruppe '{gruppe_original}': {e_attr}") except Exception as e_table: - print(f"Fehler bei Tabelle/Footer für Gruppe '{gruppe_original}': {e_table}") + print(f"Allgemeiner Fehler bei Tabelle/Footer für Gruppe '{gruppe_original}': {e_table}") additional_requests_fallback.append({'insertText': {'endOfSegmentLocation': {}, 'text': f"\nFEHLER BEI TABELLE {gruppe_original}\n"}}) - if i < len(sorted_gruppen_namen) - 1: - try: - # KORREKTER METHODENNAME: insert_page_break - gtable_manager.insert_page_break(index=None) - except Exception as e_pb: - print(f"Fehler beim Einfügen des PageBreak nach {gruppe_original}: {e_pb}") - additional_requests_fallback.append({'insertPageBreak': {'endOfSegmentLocation': {}}}) + + # if i < len(sorted_gruppen_namen) - 1: + # try: + # # HIER DER KORREKTE METHODENAUFRUF FÜR PAGEBREAK + # # gtable_manager.RICHTIGER_NAME_FUER_PAGEBREAK(index=None) + # pass + # except Exception as e_pb: + # print(f"Fehler beim Einfügen des PageBreak nach {gruppe_original}: {e_pb}") + # additional_requests_fallback.append({'insertPageBreak': {'endOfSegmentLocation': {}}}) if additional_requests_fallback and docs_api_service: try: @@ -133,24 +118,16 @@ def generate_tables_with_gdoctableapp(docs_api_service, document_id_to_fill): return True # --- Main execution block --- -# (Bleibt weitgehend gleich, ruft generate_tables_with_gdoctableapp auf) if __name__ == "__main__": print(f"Info: Ordner-ID für Dokument: '{TARGET_FOLDER_ID}'") - # Wichtig: discovery.build wird für das resource Objekt der Lib gebraucht, - # unser get_services_with_service_account gibt aber das schon gebaute service Objekt zurück. - # Wir sollten `creds` zurückgeben und den Service ggf. neu bauen oder das `resource` Objekt anpassen. - # Einfacher: `docs_api_service` ist das, was die Lib als `docsService` braucht. - docs_api_service, drive_api_service = get_services_with_service_account() if not docs_api_service: print("Konnte Google Docs API Service nicht initialisieren. Skript wird beendet.") else: document_id = None - # 1. Dokument erstellen (wie zuvor) - # ... (Code für Dokumenterstellung bleibt gleich) ... + # 1. Dokument erstellen if drive_api_service and TARGET_FOLDER_ID: - # ... (Drive API Erstellung) ... file_metadata = {'name': GOOGLE_DOC_TITLE, 'mimeType': 'application/vnd.google-apps.document', 'parents': [TARGET_FOLDER_ID]} try: created_file = drive_api_service.files().create(body=file_metadata, fields='id').execute() @@ -167,17 +144,18 @@ if __name__ == "__main__": if document_id: # 2. Einmalige Info am Anfang - # ... (Code für initial_info bleibt gleich, wird mit docs_api_service.batchUpdate eingefügt) ... initial_info_lines = ["Info zum Kopieren für Ihre manuelle Kopfzeile:", EINRICHTUNG_INFO, FOTODATUM_INFO, "\n" + "="*70 + "\n" ] initial_text = "\n".join(initial_info_lines) + "\n"; initial_requests = [{'insertText': {'location': {'index': 1}, 'text': initial_text}}] try: docs_api_service.documents().batchUpdate(documentId=document_id, body={'requests': initial_requests}).execute(); print("Einmalige Info eingefügt.") except HttpError as err: print(f"Fehler bei einmaliger Info: {err}") - # 3. Dokument mit Tabellen befüllen - success_filling = generate_tables_with_gdoctableapp(docs_api_service, document_id) + # 3. Dokument mit Tabellen befüllen (wird nach dir() Ausgabe beendet) + success_filling = generate_tables_with_gdoctableapp(docs_api_service, document_id) # Name beibehalten - if success_filling: - print(f"\n--- SKRIPT BEENDET ---"); print(f"Dokument-ID: {document_id}"); print(f"Link: https://docs.google.com/document/d/{document_id}/edit") - print("HINWEIS: Es wurde versucht, echte Tabellen mit fetter Kopfzeile via gdoctableapppy zu erstellen.") - else: print("\n--- FEHLER BEIM BEFÜLLEN MIT TABELLEN ---") + if success_filling: # Wird hier nicht viel bedeuten, da das Skript vorher abbricht + print(f"\n--- SKRIPT DEBUG-LAUF BEENDET (NACH dir()) ---") + print(f"Dokument-ID: {document_id}") + print(f"Link: https://docs.google.com/document/d/{document_id}/edit") + print("Bitte die Ausgabe von 'dir(gtable_manager)' prüfen.") + else: print("\n--- FEHLER VOR DEM EIGENTLICHEN BEFÜLLEN (DEBUG-LAUF) ---") else: print("\n--- FEHLGESCHLAGEN: Kein Dokument erstellt ---") \ No newline at end of file