На самом деле вы не создаете mailmerge.
Вот некоторый код (см. Примечание ниже), который может помочь.Он использует компонент TWordApplication
Delphi для обработки соединения и предоставления типов данных, но он должен дать вам направление для ввода:
// Drop a TWordApplication (from the Servers palette page) on a new blank form,
// and change it's name to WordApp. No other property changes or components are
// used.
procedure TForm1.FormCreate(Sender: TObject);
var
Doc: _Document;
DBName: string;
Pause, SQL, Connection, SaveChanges: OleVariant;
begin
WordApp.Connect;
Doc := WordApp.Documents.AddOld(EmptyParam, EmptyParam);
WordApp.Visible := True;
SetUpMergeDoc(Doc);
DBName := 'YourDatabasePath\DatabaseName';
Connection := 'YourADOorODBCConnectionString';
SQL := 'SELECT * FROM customer';
Doc.MailMerge.OpenDataSource(DBName, EmptyParam, EmptyParam, EmptyParam,
EmptyParam, EmptyParam, EmptyParam, EmptyParam,
EmptyParam, EmptyParam, EmptyParam, Connection,
SQL, EmptyParam, EmptyParam, EmptyParam);
// Do the actual mailmerge.
Pause := False;
Doc.MailMerge.Destination := wdSendToNewDocument;
Doc.MailMerge.Datasource.FirstRecord := wdDefaultFirstRecord;
Doc.MailMerge.Datasource.LastRecord := integer(wdDefaultLastRecord);
Doc.MailMerge.Execute(Pause);
// Save the mailmerged document
SaveChanges := wdDoNotSaveChanges;
WordApp.Quit(SaveChanges, EmptyParam, EmptyParam);
Doc := nil;
WordApp := nil;
end;
procedure TForm1.SetUpMergeDoc(Doc: _Document);
var
R: Range;
Direction: OleVariant;
begin
R := Doc.Range(EmptyParam, EmptyParam);
Direction := wdCollapseEnd;
R.InsertAfter('Dear ');
R.Collapse(Direction);
{ Insert a field with the name of the datasource field }
Doc.MailMerge.Fields.Add(R, 'Company');
R := Doc.Range(EmptyParam, EmptyParam);
R.Collapse(Direction);
R.InsertParagraphAfter;
R.InsertAfter('We have yet to receive payment for our invoice of ');
R.Collapse(Direction);
Doc.MailMerge.Fields.Add(R, 'LastInvoiceDate');
R := Doc.Range(EmptyParam, EmptyParam);
R.Collapse(Direction);
R.InsertAfter('.');
R.InsertParagraphAfter;
R.InsertAfter('Cough up or we''ll send the boys round.');
R.InsertParagraphAfter;
end;
ПРИМЕЧАНИЕ. Большая часть этого кода была получена из загруженного пример Я получил со страницы Word автоматизации веб-сайта Деборы Пейт .(Дебора была (и все еще может быть) членом TeamB.) Я просто изменил ее для подключения через TWordApplication
и обновил до компиляции в Delphi XE.
Как я уже сказал, он использует TWordApplication
дляустановить соединение с Word и раскрыть используемые методы и типы.Все остальное делается в самом коде.