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

Ошибка в обработке кнопки при выводе отчета в Excel

23.12.2018, 12:02. Показов 732. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Добрый день, выдает ошибки в обработки 3 кнопки(вывод отчета в exel): XLApp.Worksheets[1].Name: ='Отчет'; // Название Отчет // первому листу книги
Colum:=XLApp.Workbooks[1].WorkSheets['Отчёт'].Columns; // указатель на //столбцы листа
ОШибки выдает:O Undeclared identifier 'Name' at line 146 (146:21)
O Expected END but received at line 146 (146:25)
O Expected the end of file but received an identifier "Workbooks' at line 147(147:14)
Вот сам код:
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
unit Unit1;
 
interface
 
uses
  Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
  Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Jpeg, IniFiles, StrUtils, Vcl.StdCtrls,
  Vcl.Mask, Vcl.DBCtrls, Vcl.ExtCtrls, Data.DB, Vcl.Grids, Vcl.DBGrids,
  Data.Win.ADODB, Unit2, ComObj, ActiveX;
 
type
  TForm1 = class(TForm)
    ADOConnection1: TADOConnection;
    ADODataSet1: TADODataSet;
    DBGrid1: TDBGrid;
    DataSource1: TDataSource;
    Button1: TButton;
    ADODataSet2: TADODataSet;
    DataSource2: TDataSource;
    Button2: TButton;
    OpenDialog1: TOpenDialog;
    DBNavigator1: TDBNavigator;
    DBEdit1: TDBEdit;
    DBEdit2: TDBEdit;
    DBEdit3: TDBEdit;
    DBEdit4: TDBEdit;
    Image1: TImage;
    Button3: TButton;
    procedure ADODataSet2AfterScroll(DataSet: TDataSet);
    procedure FormActivate(Sender: TObject);
    procedure Button1Click(Sender: TObject);
    procedure Button2Click(Sender: TObject);
    procedure ADODataSet1AfterScroll(DataSet: TDataSet);
    procedure DBNavigator1Click(Sender: TObject; Button: TNavigateBtn);
    procedure Image1Click(Sender: TObject);
    procedure FormClose(Sender: TObject; var Action: TCloseAction);
    procedure ADOConnection1BeforeConnect(Sender: TObject);
    procedure Button3Click(Sender: TObject);
  private
    { Private declarations }
         aPath: string;
         procedure ShowImage(img: string);// отображает картинку в поле Imagе.
  public
    { Public declarations }
  end;
 
var
  Form1: TForm1;
 
implementation
{$R *.dfm}
 
// начало работы программы
 
 
procedure TForm1.ADOConnection1BeforeConnect(Sender: TObject);
var
p1,p2: integer;
IniFile: TIniFile;
fn: string; // имя INI-файла
st: string; // строка соединения
begin
// INI-файл должен находиться в том же каталоге, что и EXE-файл
// программы работы с БД  и его имя совпадает с именем EXE-файла
p1 := Pos('.exe', Application.ExeName);
fn := Copy(Application.ExeName, 1, p1-1) + '.ini';
IniFile := TIniFile.Create(fn);
// ключ aPath находится в секции data
aPath := IniFile.ReadString('data','aPath','');
if aPath = '' then
MessageDlg('Нет файла: '+ fn ,mtError,[mbOk],0);
st := ADOConnection1.ConnectionString;
p1 := Pos('Data Source',st);
p2 := PosEx(';',st,p1);
Delete(st,p1,p2-p1);
Insert('Data Source='+ aPath+ 'prodazhy.mdb',st,p1);
ADOConnection1.ConnectionString := st;
end;
 
 
 
procedure TForm1.ADODataSet1AfterScroll(DataSet: TDataSet);
var
img: string;
begin
if ADODataSet2.RecNo <> -1 then
begin
if ADODataSet2.FieldValues['img'] <> Null then
img := ADODataSet2.FieldValues['img']
else
img := '';
ShowImage(img);
end
end;
// отображает иллюстрацию
 
 
procedure TForm1.ADODataSet2AfterScroll(DataSet: TDataSet);
 var
img: string;
begin
if ADODataSet2.RecNo <> -1 then begin if ADODataSet2.FieldValues['img'] <> Null then
img := ADODataSet2.FieldValues['img']
else
img := '';
ShowImage(img);
 end;
 end;
 
 
procedure TForm1.Button1Click(Sender: TObject);
begin
Form2.ShowModal; // отобразить форму "Найти"
if Form2.ModalResult = mrOk then
// пользователь ввел критерий запроса и нажал кнопку OK
begin
// фильтр
ADODataSet1.Filtered := False;
ADODataSet1.Filter :='name Like ''%' + Form2.Edit1.Text + '%''';
ADODataSet1.Filtered := True;
if ADODataSet1.RecordCount < 0 then
begin
// в базе данных нет записей, удовлетворяющих критерию запроса
ADODataSet1.Filtered := False;
ShowMessage('В БД нет записей, удовлетворяющих критерию запроса.');
end;
end;
end;
procedure TForm1.Button2Click(Sender: TObject);
begin
ADODataSet1.Filtered := False;
end;
 
 
procedure TForm1.Button3Click(Sender: TObject);
var
XLApp,Sheet,Colum:Variant;    // Тип данных Variant может принимать
// любые значения
index,i:Integer;
begin
XLApp:= CreateOleObject('Excel.Application');  // Создаем объект EXCEL и     // записываем его в переменную XLApp.
XLApp.Visible:=true;                           // Делаем  объект EXCEL видимым
XLApp.Workbooks.Add(-4167) ;        // Создаем новую книгу Excel.
// Число (-4167)  константа, означающая  создание книги. Не  изменять!
 
XLApp.Worksheets[1].Name: ='Отчет';  // Название Отчет         // первому листу книги
Colum:=XLApp.Workbooks[1].WorkSheets['Отчёт'].Columns; // указатель на //столбцы листа
 
// Устанавливаем ширину столбцов 15, где будут данные
Colum.Columns[0].ColumnWidth:=20;
Colum.Columns[1].ColumnWidth:=20;
Colum.Columns[2].ColumnWidth:=10;
Colum.Columns[3].ColumnWidth:=20;
            Colum:=XLApp.Workbooks[1].WorkSheets['Отчёт'].Rows; //указатель  на строки
// Форматируем первые две строки
Colum.Rows[2].Font.Bold:=true;                // строка 2  жирный шрифт
    Colum.Rows[1].Font.Bold:=true;             //строка 1  жирный шрифт
    Colum.Rows[1].Font.Color:=clBlue;       // строка 1  синий цвет
    Colum.Rows[1].Font.Size:=14; // строка 1  размер шрифта 14
 Sheet:=XLApp.Workbooks[1].Worksheets['Отчёт']; // указатель на лист с названием 'Отчет' книги Excel
// Заполняем ячейки первых двух строк (шапка отчета)
Sheet.Cells[1,2]:='Имя';
Sheet.Cells[2,1]:='Фамилия';
Sheet.Cells[2,2]:='Отчество';
Sheet.Cells[2,3]:='Группа';
index:=3;  // номер строки, куда заносятся данные отчета
ADODataSet1.First; // курсор на начало первой записи в таблице запроса
  // Цикл по записям запроса в ADODataSet1, пока не будет конец файла
 
 while not  ADODataSet1.EOF do
 
begin  // Заполняем ячейки Excel данными
Sheet.Cells[index,1]:=ADODataSet1. Fields. Fields [0] .AsString;
Sheet.Cells[index,2]:=ADODataSet1.Fields.Fields[1].AsString;
Sheet.Cells[index,3]:=ADODataSet1.Fields.Fields[3].AsString;
Sheet.Cells[index,4]:=FormatDateTime('1dddddd',ADODataSet1.Fields.Fields[4].AsDateTime);
Inc(index); // Увеличиваем переменную index на 1
ADODataSet1. Next; // Перемещаемся на следующую запись
end;
end;
 
 
end;
 
procedure TForm1.DBNavigator1Click(Sender: TObject; Button: TNavigateBtn);
begin
case Button of
nbInsert, nbDelete, nbEdit:
begin
DBEdit1.ReadOnly := False;
DBEdit2.ReadOnly := False;
Image1.Enabled := True;
if Button = nbInsert then
ShowImage('nobody.jpg');
end ;
nbPost, nbCancel:
begin
DBEdit1.ReadOnly := True;
DBEdit2.ReadOnly := True;
DBEdit3.ReadOnly := True;
Image1.Enabled := False;
end ;
end;
end;
// щелчок в поле компонента Image (выбор картинки)
 
 
// щелчок на кнопке "Все записи"
 
 
procedure TForm1.FormActivate(Sender: TObject);
begin
  aPath :='C:\курсач\';
 try
ADOConnection1.Open;
ADODataSet1.Active := True;
 ADODataSet2.Active := True;
except
on e:Exception do begin
 DBGrid1.Enabled := False;
 DBEdit1.Enabled := False;
DBEdit2.Enabled := False;
DBNavigator1.Enabled := False;
 MessageDlg('Нет файла C:\курсач\tab.mdb', mtError, [mbOk], 0);
 end;
end;
 
end;
 procedure TForm1.FormClose(Sender: TObject; var Action: TCloseAction);
begin
    if ADODataSet1.State = dsEdit then // пользователь не завершил
// редактирование
begin
// записать редактируемую запись
ADODataset1.UpdateBatch(arCurrent);
end;
 
end;
 
procedure TForm1.Image1Click(Sender: TObject);
var
nFileName: string;
begin
OpenDialog1.FileName := '*.jpg';
if OpenDialog1.Execute then
begin
// пользователь выбрал изображение
nFileName := ExtractFileName(OpenDialog1.FileName);
CopyFile(PChar(OpenDialog1.FileName),
PChar(aPath + 'images\'+ nFileName), false);
ShowImage(nFileName);
ADODataSet2.FieldValues['img'] := nFileName;
end;
end;
// завершение работы программы
 
 
procedure TForm1.ShowImage(img: string);
begin
if img = '' then
img := 'nobody.jpg';
try
Image1.Picture.LoadFromFile(aPath+'images\'+img);
finally
end;
end;// добавляем просто из ворда
// щелчок на кнопке компонента DBNavigator
 
 
 
 
 
end.
Добавлено через 10 минут
XLApp.Workbooks[1].Worksheets[1].Name: ='Отчет'; //название отчета
подчеркивает Worksheets и Name

Colum:=XLApp.Workbooks[1].WorkSheets['Отчёт'].Columns; // указатель на //столбцы листа
подчеркивает Workbooks
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
23.12.2018, 12:02
Ответы с готовыми решениями:

Ошибка при выводе отчета в Excel
Здравствуйте! Возникла такая ошибка: Identifier expected but ' на строке:Sum := Sum +...

Ошибка при локальной обработке отчета
Warning warnings; string streamids; string mimeType; string encoding; string filenameExtension;...

При выводе отчета выдается ошибка
Здравствуйте пытаюсь вывести отчет Fast Rteport. Net таким образом передав SQL запрос в отчет. ...

Ошибка при выводе на печать отчета
Добрый день. Просьба помочь. При нажатии в бд на кнопку &quot;Print&quot; перед выводом на печать...

1
5395 / 4323 / 1060
Регистрация: 29.08.2013
Сообщений: 27,129
Записей в блоге: 3
23.12.2018, 18:05 2
попробуй так

Delphi
1
XLApp.Worksheets.Name: ='Отчет'
1
23.12.2018, 18:05
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
23.12.2018, 18:05
Помогаю со студенческими работами здесь

Ошибка при выводе в excel
Всем привет друзья! У меня вопрос связанный с выводом БД access в excel.Пытаюсь вывести таким...

Ошибка при выводе в Excel
При выводе данных с программы в Excel проявляется ошибка. При этом данные выгружаются все без...

Ошибка в обработке и выводе одномерного массива
Доброго времени суток! Помогите, пожалуйста, решить проблему Программа не обрабатывает или не...

Ошибка при нажатии кнопки с выводом отчета на экран
Добрый день. Простите меня пожалуйста за назойливость, но я и правда в ступоре((( Есть форма...


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

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