Карта сайта Kansoftware
НОВОСТИУСЛУГИРЕШЕНИЯКОНТАКТЫ
KANSoftWare

Как заменить текст в документе MS Word

Delphi , Технологии , OLE Automation MSOffice

Как заменить текст в документе MS Word

Автор: http://www.swissdelphicenter.ch

{
  This function starts a hidden word instance, opens a specified document "ADocument"
  and replaces (all) occurrences of "SearchString" with a specified "ReplaceString".
  The function is similar to the Delphi StringReplace() function.
}

uses
  ComObj;

// Replace Flags
type
  TWordReplaceFlags = set of (wrfReplaceAll, wrfMatchCase, wrfMatchWildcards);

function Word_StringReplace(ADocument: TFileName; SearchString, ReplaceString:
  string; Flags: TWordReplaceFlags): Boolean;
const
  wdFindContinue = 1;
  wdReplaceOne = 1;
  wdReplaceAll = 2;
  wdDoNotSaveChanges = 0;
var
  WordApp: OLEVariant;
begin
  Result := False;

  { Check if file exists }
  if not FileExists(ADocument) then
  begin
    ShowMessage('Specified Document not found.');
    Exit;
  end;

  { Create the OLE Object }
  try
    WordApp := CreateOLEObject('Word.Application');
  except
    on E: Exception do
    begin
      E.Message := 'Word is not available.';
      raise;
    end;
  end;

  try
    { Hide Word }
    WordApp.Visible := False;
    { Open the document }
    WordApp.Documents.Open(ADocument);
    { Initialize parameters}
    WordApp.Selection.Find.ClearFormatting;
    WordApp.Selection.Find.Text := SearchString;
    WordApp.Selection.Find.Replacement.Text := ReplaceString;
    WordApp.Selection.Find.Forward := True;
    WordApp.Selection.Find.Wrap := wdFindContinue;
    WordApp.Selection.Find.Format := False;
    WordApp.Selection.Find.MatchCase := wrfMatchCase in Flags;
    WordApp.Selection.Find.MatchWholeWord := False;
    WordApp.Selection.Find.MatchWildcards := wrfMatchWildcards in Flags;
    WordApp.Selection.Find.MatchSoundsLike := False;
    WordApp.Selection.Find.MatchAllWordForms := False;
    { Perform the search}
    if wrfReplaceAll in Flags then
      WordApp.Selection.Find.Execute(Replace := wdReplaceAll)
    else
      WordApp.Selection.Find.Execute(Replace := wdReplaceOne);
    { Save word }
    WordApp.ActiveDocument.SaveAs(ADocument);
    { Assume that successful }
    Result := True;
    { Close the document }
    WordApp.ActiveDocument.Close(wdDoNotSaveChanges);
  finally
    { Quit Word }
    WordApp.Quit;
    WordApp := Unassigned;
  end;
end;

procedure TForm1.Button1Click(Sender: TObject);
begin
  Word_StringReplace('C:\Test.doc', 'Old String', 'New String',
    [wrfReplaceAll]);
end;

Это программное обеспечение на языке Delphi, использующее COM для взаимодействия с Microsoft Word и замены всех вхождений указанной строки в документе.

Следующий шаг:

  1. Функция Word_StringReplace принимает четыре параметра:
    • ADocument: имя файла документа Word, который нужно изменить
    • SearchString и ReplaceString: строки для поиска и замены соответственно
    • Flags: набор флагов, контролирующих поведение замены (см. ниже)
  2. Функция проверяет, существует ли указанный документ, и выходит, если нет.
  3. Она создает объект OLE (WordApp), представляющий приложение Word.
  4. Она скрывает приложение Word и открывает указанный документ.
  5. Она настраивает диалог поиска для поиска строки SearchString:
    • ClearFormatting: очищает любое форматирование, примененное к предыдущему поиску
    • Text: устанавливает строку поиска
    • Replacement.Text: устанавливает строку замены
    • Forward: устанавливает направление поиска (истина - вперед, ложь - назад)
    • Wrap: указывает, следует ли обходить конец документа (wdFindContinue = истина)
  6. Она применяет указанные флаги для контроля поведения замены:
    • wrfMatchCase: учитывает регистр, если установлен
    • wrfMatchWildcards: использует вイルдкарды в строке поиска, если установлен
  7. Если флаг ReplaceAll установлен, функция выполняет глобальную замену; иначе - только первую замену.
  8. Она сохраняет измененный документ и закрывает его без сохранения изменений.

Флаги определены как тип перечисления (TWordReplaceFlags) с тремя возможными значениями: * wrfReplaceAll: заменяет все вхождения * wrfMatchCase: учитывает регистр * wrfMatchWildcards: использует вилдкарды в строке поиска

В примере кода обработчик события Button1Click вызывает функцию Word_StringReplace с конкретным именем файла документа и параметрами замены.

Некоторые предложения для улучшения:

  • Рассмотрите добавление обработки ошибок, чтобы поймать любые исключения, которые могут возникнуть во время процесса замены.
  • Вам может потребоваться добавить больше флагов для контроля поведения замены (например, игнорирование пробелов, сохранение форматирования).
  • Если вы планируете использовать это код в производственной среде, рассмотрите реализацию способа уничтожения объекта OLE (WordApp) для предотвращения утечек памяти.

В целом, это полезное инструментарий, который может быть расширен и настроен для конкретных случаев использования.

В этой статье описывается способ замены текста в документе Microsoft Word с помощью Delphi, используя функцию Word_StringReplace.


Комментарии и вопросы

Получайте свежие новости и обновления по Object Pascal, Delphi и Lazarus прямо в свой смартфон. Подпишитесь на наш Telegram-канал delphi_kansoftware и будьте в курсе последних тенденций в разработке под Linux, Windows, Android и iOS




Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.


:: Главная :: OLE Automation MSOffice ::


реклама


©KANSoftWare (разработка программного обеспечения, создание программ, создание интерактивных сайтов), 2007
Top.Mail.Ru

Время компиляции файла: 2024-08-19 13:29:56
2024-11-21 11:45:58/0.005511999130249/1