Форум программистов, компьютерный форум, киберфорум
Delphi для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.87/172: Рейтинг темы: голосов - 172, средняя оценка - 4.87
0 / 0 / 0
Регистрация: 01.07.2011
Сообщений: 19
1

Как записать данные в файл MS Word

15.02.2012, 22:53. Показов 35816. Ответов 73

Author24 — интернет-сервис помощи студентам
Есть файл word. как его можно заполнить через делфи? если такое конечно вообще возможно. я в делфи разбираюсь плохо.
проект делфи связан с бд access. нужно чтобы было так: занёс через делфи данные в документ определенные и распечатал, чтобы получится как отчет.
Вложения
Тип файла: doc otchet.doc (30.5 Кб, 440 просмотров)
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
15.02.2012, 22:53
Ответы с готовыми решениями:

Файл: Как с помощью Python записать (а не перезаписать) данные из базы SQLite в файл lex.txt.
Помогите с разработкой части проекта, пожалуйста! Есть файл db.sqlite в котором таджикские слова:...

Как сохранить в word-файл данные с 4-х форм?
Подскажите, как в одной процедуре, предназначенной для кнопки 'Сохранить', прописать все...

Как записать в файл данные?
Вот готовый код: #include <iostream> #include <stdlib.h> #include <locale> #include...

Файл. Как записать данные?
Доброго времени суток... просьба помочь с программой. Програма вычисляет корень квадратный в...

73
1 / 1 / 0
Регистрация: 14.05.2015
Сообщений: 26
23.10.2015, 16:03 61
Author24 — интернет-сервис помощи студентам
Цитата Сообщение от Mawrat Посмотреть сообщение
Работа с механизмом закладок MS Word даёт большие возможности. Можно не только записывать текст закладок, но и обратно - читать данные закладок из документа.
Скажите, а можно сделать так, чтобы нужный файл открывался автоматически ? На тот случай если шаблонов много.
0
13104 / 5885 / 1706
Регистрация: 19.09.2009
Сообщений: 8,808
24.10.2015, 18:01 62
Цитата Сообщение от Alienvlg Посмотреть сообщение
Скажите, а можно сделать так, чтобы нужный файл открывался автоматически ? На тот случай если шаблонов много.
Можно. Только надо знать правило по которому следует выбирать имена шаблонов. И надо знать расположение шаблонов - например, относительно папки, в которой расположен исполняемый файл программы.
1
1 / 1 / 0
Регистрация: 14.05.2015
Сообщений: 26
24.10.2015, 18:46 63
Спасибо очень помогло.
0
13104 / 5885 / 1706
Регистрация: 19.09.2009
Сообщений: 8,808
25.10.2015, 03:57 64
Т. е., как я понял, задача в том, чтобы открывать нужные файлы (шаблоны) без диалога выбора файла. Для этого можно в том директории, где расположен исполняемый файл программы, завести отдельную папку, где будут лежать файлы шаблонов. Пускай название такой папки будет таким: Templates. Тогда действия могут быть такими:
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
uses
  ComObj;
 
procedure TForm1.Button1Click(Sender: TObject);
var
  wdApp, wdDocs, wdDoc, wdBms : OleVariant;
  Path : String;
begin
  //Полный путь папки, в которой лежат файлы шаблонов. Эта папка лежит
  //в том же директории, где находится исполняемый файл программы.
  Path := ExtractFilePath(ParamStr(0)) + 'Templates\';
  //Попытка запуска экземпляра MS Word и получения ссылки на интерфейс
  //его корневого объекта (Word.Application).
  try
    wdApp := CreateOleObject('Word.Application');
  except
    MessageBox(Handle, 'Не удалось запустить MS Word. Действие отменено.',
      'Внимание!', MB_OK + MB_ICONWARNING + MB_APPLMODAL);
    Exit;
  end;
 
  //Делаем видимым окно MS Word.
  wdApp.Visible := True;
  //Ссылка на интерфейс коллекции документов.
  wdDocs := wdApp.Documents;
  //Попытка открыть файл шаблона и получить ссылку на интерфейс документа.
  wdDoc := wdDocs.Open(FileName:=Path + 'template-01.doc');
  //Получаем ссылку на интерфейс коллекции закладок.
  wdBms := wdDoc.Bookmarks;
  
  //Далее работаем с закладками.
  //...
  //...
  //...
end;
1
1 / 1 / 0
Регистрация: 14.05.2015
Сообщений: 26
25.12.2015, 10:54 65
Подскажите пожалуйста. Хочу используя закладки применить checkbox. Пример: если checkbox = true, то он в поле закладки вставляет "ХХХ", если checkbox = false, то "YYY"
0
13104 / 5885 / 1706
Регистрация: 19.09.2009
Сообщений: 8,808
28.12.2015, 08:56 66
Цитата Сообщение от Alienvlg Посмотреть сообщение
Подскажите пожалуйста. Хочу используя закладки применить checkbox. Пример: если checkbox = true, то он в поле закладки вставляет "ХХХ", если checkbox = false, то "YYY"
Например, так можно сделать:
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
uses
  ComObj;
 
{ Функция записывает новый текст aText для закладки с именем aBmName.
  aBmx - ссылка на интерфейс коллекции закладок: Word.Document.Bookmarks
  Функция возвращает значение True, если закладка найдена и её текст изменён
  и False - если закладка не найдена.
  Переустановка текста закладки выплоняется так:
  - Получаем ссылку на интерфейс объекта-диапазона, который содержит текст закладки.
  - Удаляем закладку.
  - Устанавливаем новый текст для объекта-диапазона.
  - Создаём новую закладку с диапазоном, который содержит новый текст.}
function SetBmText(var aBms : OleVariant; const aBmName, aText : String) : Boolean;
var
  Bm, Rng : OleVariant;
begin
  Result := aBms.Exists(aBmName); //Проверяем - существует ли закладка с заданным именем.
  if not Result then              //Если закладка не найдена - выходим.
    Exit;
 
  Bm := aBms.Item(aBmName); //Ссылка на интерфейс закладки.
  Rng := Bm.Range;          //Ссылка на интерфейс диапазона, связанного с закладкой.
  Bm.Delete;                //Удаление закладки.
  Rng.Text := aText;        //Заменяем текст в диапазоне.
  aBms.Add(aBmName, Rng);   //Добавляем новую закладку с таким же именем.
end;
 
procedure TForm1.Button1Click(Sender: TObject);
var
  wdApp, wdDocs, wdDoc, wdBms : OleVariant;
  Od : TOpenDialog;
begin
  //Диалог выбора файла.
  Od := OpenDialog1; //OpenDialog1 уже должен быть на форме.
  //ExtractFilePath(ParamStr(0)) - Полный путь директория, в котором лежит исполняемый файл программы.
  if Od.InitialDir = '' then
    Od.InitialDir := ExtractFilePath(ParamStr(0)) + 'Files\';
  Od.Title := 'Выберите файл шаблона для создания нового документа';
  if not Od.Execute then
    Exit;
  if not FileExists(Od.FileName) then
  begin
    MessageBox(Handle, 'Файл с заданным именем не найден. Действие отменено.',
      'Внимание!', MB_YESNO + MB_ICONEXCLAMATION + MB_APPLMODAL);
    Exit;
  end;
 
  //Попытка запустить экземпляр MS Word и получить ссылку на интерфейс его корневого объекта Word.Application.
  try
    wdApp := CreateOleObject('Word.Application');
  except
    ShowMessage('Не удалось запустить MS Word. Действие отменено.');
    Exit;
  end;
 
  wdApp.Visible := True;     //Делаем видимым окно MS Word.
  wdDocs := wdApp.Documents; //Ссылка на интерфейс коллекции документов.
  wdDoc := wdDocs.Open(FileName:=Od.FileName); //Открываем документ.
  wdBms := wdDoc.Bookmarks;      //Подключаемся к коллекции закладок.
  wdApp.ScreenUpdating := False; //Отключение перерисовки окна MS Word. - Для ускорения работы.
 
  //Ищем закладки с нужными именами и изменяем их содержимое в зависимости
  //от установленных переключателей (TCheckBox).
  if CheckBox1.Checked then
    SetBmText(wdBms, 'CHECK_01', 'CHECK_01 - ДА')
  else
    SetBmText(wdBms, 'CHECK_01', 'CHECK_01 - НЕТ');
 
  if CheckBox2.Checked then
    SetBmText(wdBms, 'CHECK_02', 'CHECK_02 - ДА')
  else
    SetBmText(wdBms, 'CHECK_02', 'CHECK_02 - НЕТ');
 
  wdApp.DisplayAlerts := False; //Запрет на показ предупреждений.
  try
    wdDoc.SaveAs(FileName:=Od.FileName + '-new.doc');
  finally
    wdApp.DisplayAlerts := True; //Разрешение на показ предупреждений.
  end;
  
  //wdDoc.Close; //Если требуется, закрываем документ.
  //wdApp.Quit;  //Если требуется, закрываем MS Word.
end;
Вложения
Тип файла: 7z MSWordSetBmByCheckBox-01.7z (175.3 Кб, 34 просмотров)
1
0 / 0 / 0
Регистрация: 08.04.2016
Сообщений: 5
08.04.2016, 11:49 67
Всем добрый день! Понимаю, что тема была создана уже весьма давно, но вдруг кто откликнется) Ответы Mawrat просто спасли меня) Разобрался, переделал под себя, все работает! Низкий поклон) Но есть небольшой вопрос (понимаю, что он может показаться достаточно глупым, но тем не менее..) если в закладки (в worde) должны вставиться данные из TDataTimePicker, то как надо переписать строку SetBmText(wdBms, 'Lic_RR_DATE', Lic_RR_DATE.Text);

ps Lic_RR_DATE - название закладки в worde и название TDataTimePicker.

Заранее спасибо!

Добавлено через 33 минуты
Решил вопрос конвертированием даты в текст)
0
1 / 1 / 0
Регистрация: 14.05.2015
Сообщений: 26
08.04.2016, 13:28 68
SetBmText(wdBms, 'DATE', FormatDateTime('dd mmmm yyyy', DateTimePicker1.Date));
1
0 / 0 / 0
Регистрация: 08.04.2016
Сообщений: 5
08.04.2016, 13:37 69
Alienvlg, Огромное спасибо! Все подошло, все работает)
0
0 / 0 / 0
Регистрация: 27.10.2015
Сообщений: 12
15.06.2016, 16:16 70
Подскажите пожалуйста, почему могут данные не появляться в закладках. Точнее часть данных отразилась, а часть нет. Закладки все присутствуют.
0
13104 / 5885 / 1706
Регистрация: 19.09.2009
Сообщений: 8,808
16.06.2016, 12:35 71
Цитата Сообщение от Anchut-ka Посмотреть сообщение
Подскажите пожалуйста, почему могут данные не появляться в закладках. Точнее часть данных отразилась, а часть нет. Закладки все присутствуют.
Надо сверить имена закладок. Они должны быть одинаковыми - в программе и в документе MS Word. В именах закладок можно пренебречь только регистром букв (и то нежелательно).
Например, может быть такая ошибка - в программе в имени закладки указана русская буква "О", а в документе MS Word закладка определена с английской буквой "O". Такая же ошибка может быть в отношении других букв, начертания которых в разных алфавитах совпадают.
1
0 / 0 / 0
Регистрация: 27.10.2015
Сообщений: 12
16.06.2016, 13:56 72
Спасибо! Значит буду переписывать все закладки, т.к. визуально вроде как один-в-один)
Подскажите еще, а возможно из dbgrid часть столбцов перенаправить в Word как текст, а часть вывести таблицей как отчет?
0
13104 / 5885 / 1706
Регистрация: 19.09.2009
Сообщений: 8,808
16.06.2016, 14:23 73
Цитата Сообщение от Anchut-ka Посмотреть сообщение
Подскажите еще, а возможно из dbgrid часть столбцов перенаправить в Word как текст, а часть вывести таблицей как отчет?
Можно как угодно выводить. Только надо учесть, что данные таблицы БД извлекаются последовательно - строка за строкой. Если какие-то данные надо вывести до таблицы или после - для этого возможно потребуется выполнить несколько проходов по набору данных или, может, удобнее будет использовать несколько запросов.
0
0 / 0 / 0
Регистрация: 27.10.2015
Сообщений: 12
17.06.2016, 11:47 74
С запросами туговато((( А есть ли у вас на примере что-то подобное?
0
17.06.2016, 11:47
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.06.2016, 11:47
Помогаю со студенческими работами здесь

Как записать данные в файл
Как записать данные в файл в определенную строку в PHP

Как записать данные в файл CSV?
Всем привет. Есть некоторые данные для записи в файл CSV (не StringGrid). Перерыл интернет, но...

Как записать данные в файл CSV
Коллеги всем добрый вечер. Прошу у Вас помощи в такой ситуации. Я разрабатываю приложения на...

как записать данные в файл txt
У меня есть текстовый файл, в нем 5 полей к примеру |1|август|2013|22 сентября 2012|3 октября...

Как записать данные с куки в файл?
Всем привет! Есть код, который записывает ссылку в куки. Мне надо, чтобы когда выполнялся условие,...

Sqlite - Как записать данные в файл?
Как правильно записать данные в файл в формате .html ? А так же если кто шарит, объясните как...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
74
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru