![]() |
Word Zellen in Tabelle verbinden (OLE)
Hi @all,
in einem Word-Dokument lasse ich eine Tabelle mit mehrern Spalten erzeugen. Jetzt sollen in mehreren (nicht allen) Zeilen Zellen verbunden werden. Der Makro-Generator hat funktionierenden VBA-Code ausgespuckt. Wenn ich diesen allerdings in Delphi-Code übersetzen, dann bricht dieser immer mit einer Fehlermeldung ab. Egal was ich versucht habe, der Tenor dieser Meldungen ist immer, dass entweder eine Funktion überhaupt nicht existiere, zu wenige oder falsche Parameter verwendet werden.
Delphi-Quellcode:
Laut
var
WordApp: OleVariant; Dokument: OleVariant; const Pfad = 'C:\Dokument.docx'; begin WordApp := CreateOleObject('Word.Application'); WordApp.Documents.Open(Pfad); Document := WordApp.ActiveDocument; // Tabelle erzeugen Document.Tables.Add(WordApp.Selection.Range, 7, 4, wdWord9TableBehavior); WordApp.Selection.TypeText('Zeile 1, Spalte 1'); WordApp.Selection.MoveRight(wdCell); WordApp.Selection.MoveRight(wdCharacter, 3, wdExtend); WordApp.Selection.Cells.Merge(); // <-- Hier der Fehler mit zu wenigen Parametern WordApp.Selection.TypeText(FieldByName('Zeile 2; 3 Spalten verbunden').AsString); WordApp.Selection.MoveRight(wdCell); WordApp.Selection.TypeText('Zeile 2, Spalte 1'); // [...] ![]() Die auf ![]() Kann mir da bitte jemand weiterhelfen? Delphi XE8 + Word 2013 Grüße |
AW: Word Zellen in Tabelle verbinden (OLE)
In der PAS-Datei zur Typelib sieht Merge so aus:
Delphi-Quellcode:
und benötigt demnach einen Parameter.
procedure Merge(const MergeTo: Cell); safecall;
Wenn ich irgendwas mit den Officeprodukten mache und bei den Parametern nicht weiter weiß, verlasse ich mich nie ausschließlich auf erstellte Makros oder irgendwelche Beispiele mit VBA ..., sondern schaue immer auch in die Typelib, da nur die mir (erfahrungsgemäß) korrekte Informationen zu den Parametern liefert. Versuch es bitte mal mit:
Delphi-Quellcode:
var
WordApp: OleVariant; Dokument: OleVariant; const Pfad = 'C:\Dokument.docx'; begin WordApp := CreateOleObject('Word.Application'); WordApp.Documents.Open(Pfad); Document := WordApp.ActiveDocument; // Tabelle erzeugen Document.Tables.Add(WordApp.Selection.Range, 7, 4, wdWord9TableBehavior); WordApp.Selection.TypeText('Zeile 1, Spalte 1'); WordApp.Selection.MoveRight(wdCell); WordApp.Selection.MoveRight(wdCharacter, 3, wdExtend); WordApp.Selection.Cells.Merge(EmptyParam); // <-- Bei Parametern, die man nicht befüllen kann oder muss, einfach EmptyParam angeben. WordApp.Selection.TypeText(FieldByName('Zeile 2; 3 Spalten verbunden').AsString); WordApp.Selection.MoveRight(wdCell); WordApp.Selection.TypeText('Zeile 2, Spalte 1'); // [...] |
AW: Word Zellen in Tabelle verbinden (OLE)
Zitat:
Delphi-Quellcode:
funktioniert nicht. Verwendet man aber
WordApp.Selection.Cells.Merge();
Delphi-Quellcode:
(Hinweis: Ohne Klammern), dann funktioniert es.
WordApp.Selection.Cells.Merge;
Danke dennoch für den Hinweis. Grüße |
AW: Word Zellen in Tabelle verbinden (OLE)
Hmm..
könnte es nicht sein, das Selection.merge keinen Parameter braucht (und somit auch keine () ). Hingegen in dem Beispiel aus dem Link mit Cell.Merge gearbeitet wird und dort eine weiter Cell angegeben werden muss, bis der ein Verbinden stattfindet... Ich schaue dann immer in der API bei Microsoft... |
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:58 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz