Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [Delphi] Код программы 
:(
    Опции темы
Отис
Дата 8.6.2014, 15:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 1
Регистрация: 8.6.2014

Репутация: нет
Всего: нет



Плиззз кто нибудь может по подробней написать комментарий к следующему коду

Код

const
wdAlignParagraphCenter = 1;
wdAlignParagraphLeft = 0;
wdAlignParagraphRight = 2;
wdLineStyleSingle = 1;
 
 
procedure TForm4.Image4Click(Sender: TObject);
var
summ,count,i,k:integer;
MSWord,wdDoc,wdTable,wdRng: Variant;
arr:array[0..3] of string;
Bm : TBookMark;
begin
arr[0]:='№';
arr[1]:='Название блюда';
arr[2]:='Порция';
arr[3]:='Цена';
try
MsWord := CreateOleObject('Word.Application');
MsWord.Visible := True;
    //MsWord := GetActiveOleObject('Word.Application');
except
end;
  ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT SUM(Цена) FROM Заказ_основного_меню WHERE Статус=true and Дата="'+FormatDateTime('dd.mm.yyyy', Now)+'"');
  ADOQuery1.Open;
summ:=ADOQuery1.Fields[0].AsInteger;
  ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT * FROM Заказ_основного_меню WHERE Статус=true and Дата="'+FormatDateTime('dd.mm.yyyy', Now)+'"');
  ADOQuery1.Open;
count:=ADOQuery1.RecordCount;
wdDoc:=MSWord.Documents.Add;
wdRng:= wdDoc.Content;
wdRng.Start := wdRng.End;
wdRng.InsertAfter('Дата: '+FormatDateTime('dd.mm.yyyy', Now)+#13);
wdRng.InsertAfter('Список заказов(Обычное меню): '+#13);
  //wdRng.InsertAfter('За сегодняшний день('+FormatDateTime('dd.mm.yyyy', Now)+') продано '+inttostr(count)+' товаров'+#13);
wdRng.ParagraphFormat.Reset;
wdRng.ParagraphFormat.Alignment := wdAlignParagraphCenter;
  wdRng.Font.Reset;
wdRng.Font.Size := 14;
wdRng.Font.Bold := False;
wdTable := wdDoc.Tables.Add(wdRng.Characters.Last, 2, 4);
wdTable.columns.item(1).Width:=22;
wdTable.columns.item(2).Width:=200;
wdTable.columns.item(3).Width:=50;
wdTable.columns.item(4).Width:=40;
wdTable.Borders.InsideLineStyle := wdLineStyleSingle;
wdTable.Borders.OutsideLineStyle := wdLineStyleSingle;
    wdRng.ParagraphFormat.Reset;
wdRng.ParagraphFormat.Alignment := wdAlignParagraphLeft;
wdRng := wdTable.Rows.Item(1).Range;
wdRng.ParagraphFormat.Alignment := wdAlignParagraphCenter;
wdRng.Font.Size := 10;
wdRng.Font.Bold := True;
wdRng := wdTable.Rows.Item(2).Range;
wdRng.ParagraphFormat.Alignment := wdAlignParagraphLeft;
wdRng.Font.Size := 10;
wdRng.Font.Bold := False;
for i := 0 to High(arr)-Low(arr) do
wdTable.Cell(1, i + 1).Range.Text := arr[i];
    ADOQuery1.DisableControls;
Bm := ADOQuery1.GetBookMark;
    ADOQuery1.First;
i := 1;
while not ADOQuery1.Eof do begin
Inc(i);
k:=k+1;
if i > 2 then wdTable.Rows.Add;
wdTable.Cell(i, 1).Range.Text := inttostr(k);
wdTable.Cell(i, 2).Range.Text := ADOQuery1.FieldByName('Наименование_блюда').AsString;
wdTable.Cell(i, 3).Range.Text := ADOQuery1.FieldByName('Порция').AsString;
wdTable.Cell(i, 4).Range.Text := ADOQuery1.FieldByName('Цена').AsString;
      ADOQuery1.Next;
end;
ADOQuery1.GotoBookMark(Bm);
    ADOQuery1.EnableControls;
      ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT SUM(Цена) FROM Заказ_банкетного_меню WHERE Статус=true and Дата="'+FormatDateTime('dd.mm.yyyy', Now)+'"');
       ADOQuery1.Open;
summ:=summ+ADOQuery1.Fields[0].AsInteger;
    ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT * FROM Заказ_банкетного_меню WHERE Статус=true and Дата="'+FormatDateTime('dd.mm.yyyy', Now)+'"');
    ADOQuery1.Open;
count:=count+ADOQuery1.RecordCount;
wdRng := wdDoc.Content;
wdRng.Start := wdRng.End;
wdRng.InsertAfter(#13#10);
wdRng.InsertAfter('Списокзаказов(Банкетноеменю): '+#13);
  //wdRng.InsertAfter('Засегодняшнийдень('+FormatDateTime('dd.mm.yyyy', Now)+') продано '+inttostr(count)+' товаров'+#13);
  wdRng.ParagraphFormat.Reset;
wdRng.ParagraphFormat.Alignment := wdAlignParagraphCenter;
  wdRng.Font.Reset;
wdRng.Font.Size := 14;
wdRng.Font.Bold := False;
wdTable := wdDoc.Tables.Add(wdRng.Characters.Last, 2, 4);
wdTable.columns.item(1).Width:=22;
wdTable.columns.item(2).Width:=200;
wdTable.columns.item(3).Width:=50;
wdTable.columns.item(4).Width:=40;
wdTable.Borders.InsideLineStyle := wdLineStyleSingle;
wdTable.Borders.OutsideLineStyle := wdLineStyleSingle;
    wdRng.ParagraphFormat.Reset;
wdRng.ParagraphFormat.Alignment := wdAlignParagraphLeft;
wdRng := wdTable.Rows.Item(1).Range;
wdRng.ParagraphFormat.Alignment := wdAlignParagraphCenter;
wdRng.Font.Size := 10;
wdRng.Font.Bold := True;
wdRng := wdTable.Rows.Item(2).Range;
wdRng.ParagraphFormat.Alignment := wdAlignParagraphLeft;
wdRng.Font.Size := 10;
wdRng.Font.Bold := False;
for i := 0 to High(arr)-Low(arr) do
wdTable.Cell(1, i + 1).Range.Text := arr[i];
    ADOQuery1.DisableControls;
Bm := ADOQuery1.GetBookMark;
    ADOQuery1.First;
i := 1;
while not ADOQuery1.Eof do begin
Inc(i);
k:=k+1;
if i > 2 then wdTable.Rows.Add;
wdTable.Cell(i, 1).Range.Text := inttostr(k);
wdTable.Cell(i, 2).Range.Text := ADOQuery1.FieldByName('Наименование_блюда').AsString;
wdTable.Cell(i, 3).Range.Text := ADOQuery1.FieldByName('Порция').AsString;
wdTable.Cell(i, 4).Range.Text := ADOQuery1.FieldByName('Цена').AsString;
      ADOQuery1.Next;
end;
ADOQuery1.GotoBookMark(Bm);
    ADOQuery1.EnableControls;
wdRng := wdDoc.Content;
wdRng.Start := wdRng.End;
wdRng.InsertAfter(#13#10);
wdRng.InsertAfter('Всегозаказов: '+inttostr(count)+#13);
wdRng.InsertAfter('Итоговаясумма: '+inttostr(summ)+' тенге');
      wdRng.ParagraphFormat.Reset;
wdRng.ParagraphFormat.Alignment := wdAlignParagraphLeft;
  wdRng.Font.Reset;
wdRng.Font.Size := 14;
wdRng.Font.Bold := False;
MSWord.Application.PrintOut(false);
MSWord.Documents.Close(false);
  MSWord.quit;
end;



M
Poseidon
Используйте кнопку user posted image


Это сообщение отредактировал(а) Poseidon - 9.6.2014, 09:32
PM MAIL   Вверх
bems
Дата 8.6.2014, 17:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 3400
Регистрация: 5.1.2006

Репутация: 0
Всего: 88



Для домашних заданий, контрольных и курсовых существует Центр помощи.

Тема перенесена! 



--------------------
Обижено школьников: 8
PM MAIL   Вверх
Данкинг
Дата 8.6.2014, 19:27 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Yersinia pestis
****


Профиль
Группа: Завсегдатай
Сообщений: 8302
Регистрация: 7.11.2006
Где: მოსკოვი

Репутация: нет
Всего: 130



Там идёт заполнение таблички в файле WORD из какой-то таблицы, к которой программа подключается через ADO.

Это сообщение отредактировал(а) Данкинг - 8.6.2014, 19:27


--------------------
There's nothing left but silent epitaphs.
PM MAIL WWW   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.0633 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.