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

Помогите в работе с таблицами Word

30.09.2009, 23:27. Показов 16715. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, уважаемые!
Прошу помощи в решении одной проблемы.
Есть проект (см.вложение). Проект создан на основе статьи Корнякова "Суперфункции".
Необходимо в программе после первичного заполнения данными строки таблицы 2 перейти к показу формы, нажать кнопку "Добавить строку", добавить в таблице 2 пустую строку, изменить значения контролов на форме (Combobox,Edit,Memo), нажать кнопку "Заполнить строку" и этими (измененными ) данными заполнить вставленную строку таблицы.
Затем по необходимости выполнить операцию (несколько раз) по добавлению пустой строки и ее заполнению,либо отказаться от этого и сохранить документ.
Никак не получается...
ПОМОГИТЕ
Заранее благодарен
Al_Sha
Вложения
Тип файла: rar Project.rar (7.5 Кб, 109 просмотров)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
30.09.2009, 23:27
Ответы с готовыми решениями:

Люди, помогите! Вопрос по работе в Builder'e с таблицами SQL
Товарищи, помогите пожалуйста. Конечно, может я не по адресу, не знаю. Вопрос такой: При подключении серверной базы данных SQL я...

Не происходят изминения при работе с таблицами
Подскажите новичку в С#. Сделал форму, сделал коннект к MSSQL, в форме открываю табличку с сервера. ПО нажатию кнопеи выполняю...

Работа с таблицами Word
Добрый день! Есть документ с макетом ActiveDocument в котором имеется таблица. Таблицу необходимо заполнять данными. В принципе само...

7
 Аватар для Mawrat
13116 / 5897 / 1708
Регистрация: 19.09.2009
Сообщений: 8,809
01.10.2009, 01:42
Посмотрел проект. У меня нет модуля ToolEdit. Но это и не важно. Все действия, которые выполняются через функции того модуля можно самому реализовать.
Завтра набросаю... - вернее уже сегодня. Но не ночью.
0
1 / 1 / 0
Регистрация: 03.04.2009
Сообщений: 38
01.10.2009, 19:31  [ТС]
Mawrat, Вроде как помощь обещалась...
0
 Аватар для Mawrat
13116 / 5897 / 1708
Регистрация: 19.09.2009
Сообщений: 8,809
01.10.2009, 21:41
Цитата Сообщение от Al_Sha Посмотреть сообщение
Mawrat, Вроде как помощь обещалась...
Извини, задержал. Сейчас выложу. Полчаса мне потребуется, примерно.

Добавлено через 47 минут
Вот реализация:
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
unit uMain;
 
interface
 
uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs
 
  ,ComObj, StdCtrls;
 
type
  TfrmMain = class(TForm)
    btnWordConnect: TButton;
    btnDocCreate: TButton;
    btnTableCreate: TButton;
    btnRowAdd: TButton;
    btnRowDel: TButton;
    btnTableDel: TButton;
    btnWordDisconnect: TButton;
    edCell1: TEdit;
    edCell2: TEdit;
    edCell3: TEdit;
    edCell4: TEdit;
    edCell5: TEdit;
    edIndexRowDel: TEdit;
    Label1: TLabel;
    Label2: TLabel;
    Label3: TLabel;
    Label4: TLabel;
    Label5: TLabel;
    edIndexRowAdd: TEdit;
    Label6: TLabel;
    procedure btnWordConnectClick(Sender: TObject);
    procedure btnDocCreateClick(Sender: TObject);
    procedure btnTableCreateClick(Sender: TObject);
    procedure btnRowAddClick(Sender: TObject);
    procedure btnRowDelClick(Sender: TObject);
    procedure btnTableDelClick(Sender: TObject);
    procedure btnWordDisconnectClick(Sender: TObject);
    procedure FormCreate(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
 
    //Ссылка на Word.Application.
    wdApp     : Variant;
    //Ссылка на документ Word.
    wdDoc     : Variant;
    //Ссылка на таблицу Word.
    wdTable   : Variant;
    //Ссылка на строку в таблице.
    wdRow     : Variant;
 
    procedure WordDisconnect();
  end;
 
var
  frmMain: TfrmMain;
 
implementation
 
{$R *.dfm}
 
//Запускаем приложение MS Word, получаем на него ссылку.
//И делаем видимым главное окно MS Word.
function WordConnect() : Variant;
begin
  TVarData(Result).VDispatch := nil;
  Result := CreateOleObject('Word.Application');
  Result.Visible := True;
end;
 
//Создает документ.
function DocCreate(aWdApp : Variant) : Variant;
begin
  TVarData(Result).VDispatch := nil;
  if TVarData(aWdApp).VDispatch = nil then begin
    Exit;
  end;
  Result := aWdApp.Documents.Add();
end;
 
//Создаёт таблицу.
function TableCreate(aWdDoc : Variant; aRowCount : Longword; aColCount : Longword) : Variant;
var
  wdRange   : Variant;
  EndIndex  : Longword;
begin
  TVarData(Result).VDispatch := nil;
  if TVarData(aWdDoc).VDispatch = nil then begin
    Exit;
  end;
  //Диапазон документа.
  wdRange := aWdDoc.Range;
  //Позиция, расположенная после последнего символа в документе.
  EndIndex := wdRange.Characters.Count - 1;
  //Диапазон, представляющий позицию в конце документа.
  wdRange := aWdDoc.Range(EndIndex, EndIndex);
  //Добавляем таблицу в конец документа.
  Result := aWdDoc.Tables.Add(wdRange, aRowCount, aColCount);
end;
 
//Удаляет таблицу.
function TableDel(var aWdTable : Variant) : Boolean;
begin
  Result := False;
  if TVarData(aWdTable).VDispatch = nil then
    Exit
  ;
  aWdTable.Delete;
  TVarData(aWdTable).VDispatch := nil;
  Result := True;
end;
 
//Добавляет новую строку в таблицу.
//Если номер строки задан отрицательным числом, то считаем, что вставку
//нужно сделать в конец таблицы.
function TableRowAdd(aWdTable : Variant; aRowNum : Integer = -1) : Variant;
var
  RowCount    : Longword;
  RowNum      : Longword;
  wdRowBefore   : Variant;
begin
  TVarData(Result).VDispatch := nil;
  if TVarData(aWdTable).VDispatch = nil then begin
    Exit;
  end;
  //Число строк в таблице.
  RowCount := aWdTable.Rows.Count;
  if aRowNum < 0 then begin
    //Подразумевается вставка в конец таблицы.
    RowNum := RowCount + 1;
  end else if aRowNum = 0 then begin
    //Строки нумеруются с единицы. Поэтому исправляем номер на 1.
    RowNum := 1;
  end else begin
    //Принимаем номер как есть.
    RowNum := aRowNum;
  end;
  if RowNum < RowCount + 1 then begin
    //Для того, чтобы добавить новую строку в позицию RowNum,
    //требуется произвести вставку перед уже имеющейся строкой с номером RowNum.
    wdRowBefore := aWdTable.Rows.Item(RowNum);
    Result := aWdTable.Rows.Add(wdRowBefore);
  end else begin
    //В случае, когда строка добавляется в конец таблицы.
    Result := aWdTable.Rows.Add();
  end;
end;
 
//Удаляет строку из таблицы. Если номер строки задан отрицательным числом,
//то считаем, что требуется удалить последнюю строку в таблице.
function TableRowDel(aWdTable : Variant; aRowNum : Integer = -1) : Boolean;
var
  RowCount    : Longword;
  RowNum      : Longword;
begin
  Result := False;
 
  if TVarData(aWdTable).VDispatch = nil then begin
    Exit;
  end;
 
  //Число строк в таблице.
  RowCount := aWdTable.Rows.Count;
 
  //Если таблица состоит из одной строки, то удаление строки считаем невозможным.
  if RowCount = 1 then begin
    Exit;
  end;
 
  if aRowNum = 0 then begin
    //Строки нумеруются с единицы, поэтому делаем поправку.
    RowNum := 1;
  end else if (aRowNum < 0) or (aRowNum > RowCount) then begin
    //В этом случае полагаем, что требуется удалить последнюю строку.
    RowNum := RowCount;
  end else begin
    //Принимаем номер как есть.
    RowNum := aRowNum;
  end;
  aWdTable.Rows.Item(RowNum).Delete;
  Result := True;
end;
 
//Записывает значение в ячейку.
procedure TableCellWrite(aWdTable : Variant; aRowIndex : Longword; aColIndex : Longword; aStrValue : String);
begin
  if TVarData(awdTable).VDispatch = nil then begin
    Exit;
  end;
  aWdTable.Cell(aRowIndex, aColIndex).Range.Text := aStrValue;
end;
 
//Читает значение из ячейки.
function TableCellRead(aWdTable : Variant; aRowIndex : Longword; aColIndex : Longword) : String;
begin
  Result := '';
  if TVarData(awdTable).VDispatch = nil then begin
    Exit;
  end;
  Result := aWdTable.Cell(aRowIndex, aColIndex).Range.Text;
end;
 
//******************************************************************************
 
procedure TfrmMain.btnWordConnectClick(Sender: TObject);
begin
  wdApp := WordConnect();
end;
 
procedure TfrmMain.btnDocCreateClick(Sender: TObject);
begin
  wdDoc := DocCreate(wdApp);
end;
 
procedure TfrmMain.btnTableCreateClick(Sender: TObject);
begin
  wdTable := TableCreate(wdDoc, 1, 5);
end;
 
procedure TfrmMain.btnRowAddClick(Sender: TObject);
begin
  //Добавляем строку.
  if edIndexRowAdd.Text <> '' then begin
    //Добавляем строку в указанную позицию.
    wdRow := TableRowAdd(wdTable, StrToInt(edIndexRowAdd.Text));
  end else begin
    //Добавляем строку в конец таблицы.
    wdRow := TableRowAdd(wdTable);
  end;
  //Заполняем строку значениями.
  TableCellWrite(wdTable, wdRow.Index, 1, edCell1.Text);
  TableCellWrite(wdTable, wdRow.Index, 2, edCell2.Text);
  TableCellWrite(wdTable, wdRow.Index, 3, edCell3.Text);
  TableCellWrite(wdTable, wdRow.Index, 4, edCell4.Text);
  TableCellWrite(wdTable, wdRow.Index, 5, edCell5.Text);
end;
 
procedure TfrmMain.btnRowDelClick(Sender: TObject);
begin
  //Удаялем строку.
  if edIndexRowDel.Text <> '' then begin
    //Удаляем строку с указанным номером.
    wdRow := TableRowDel(wdTable, StrToInt(edIndexRowDel.Text));
  end else begin
    //Удаляем нижнюю строку в таблице.
    wdRow := TableRowDel(wdTable);
  end;
end;
 
procedure TfrmMain.btnTableDelClick(Sender: TObject);
begin
  TableDel(wdTable);
end;
 
procedure TfrmMain.btnWordDisconnectClick(Sender: TObject);
begin
  WordDisconnect();
end;
 
procedure TfrmMain.FormCreate(Sender: TObject);
begin
  WordDisconnect();
end;
 
procedure TfrmMain.WordDisconnect;
begin
  //Обнуление ссылок.
  TVarData(wdRow).VDispatch := nil;
  TVarData(wdTable).VDispatch := nil;
  TVarData(wdDoc).VDispatch := nil;
  TVarData(wdApp).VDispatch := nil;
end;
 
end.
Здесь реализованы основные действия: подключение к MS Word, создание нового документа, создание таблицы, добавление строк в таблицу, удаление строк из таблицы, запись значений в ячейки таблицы, чтение значений из ячеек таблицы, удаление таблицы, отключение от MS Word.
Для выполнения действий на форму положены кнопки и элементы редактирования.
Для добавления и удаления строк таблицы вводить индекс добавляемой/удаляемой строки не обязательно. - Если индекс не записан, то добавление/удаление производится в конце таблицы.
2
 Аватар для Mawrat
13116 / 5897 / 1708
Регистрация: 19.09.2009
Сообщений: 8,809
01.10.2009, 21:45
И сам проект:
Вложения
Тип файла: rar Управление таблицами MS Word.rar (178.2 Кб, 700 просмотров)
1
1 / 1 / 0
Регистрация: 03.04.2009
Сообщений: 38
01.10.2009, 22:44  [ТС]
Премного благодарен, многое стало понятным.
Скорее всего от своего проекта откажусь и воспользуюсь как основой "Управление таблицами MS Word"
Еще раз спасибо
Al_Sha

Добавлено через 56 секунд
Mawrat, СПАСИБО !!!!
0
0 / 0 / 0
Регистрация: 17.06.2014
Сообщений: 1
29.10.2009, 09:48
Блин... почему я немогу скачать архив....?
0
1 / 1 / 0
Регистрация: 03.04.2009
Сообщений: 38
29.10.2009, 22:11  [ТС]
Цитата Сообщение от TMonax Посмотреть сообщение
Блин... почему я немогу скачать архив....?
Странно, все вроде скачивается.....
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.10.2009, 22:11
Помогаю со студенческими работами здесь

Работа с таблицами word
Подскажите пожалуйста новичку!! Есть написанное приложение где при нажатии кнопки создаётся таблица в word. Необходимо после её...

Работа с таблицами Word
Подскажите пожалуйста что я делаю не так. Хочу создать таблицу и задать её формат но Делфи выдает ошыбку. procedure...

При работе с таблицами в Access исчезло приличное кол-во БД
Добрый день! При работе с таблицами в Access ,а именно через &quot;Конструктор запросов&quot; я соединяла данные таблицы. Есть основная...

Работа с таблицами и формулами Word
Здравствуйте, помогите пожалуйста с работой таблицами и формулами в Word

Переключение между таблицами Word
Обращаюсь к первой таблице документа: Table:= MSWORD.ActiveDocument.Tables.Item(1); Далее заполняю таблицу.. все проходит успешно. Затем...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru