Показать сообщение отдельно
  #1  
Старый 05.04.2021, 08:11
denzenit denzenit вне форума
Прохожий
 
Регистрация: 16.12.2020
Сообщения: 11
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию Универсальность цикла, увеличение дальшейней поддержки

Имеется следующий цикл, который распределяет полученную информацию из запроса, который соответствует i. общий цикл for i := 1 to maxI do, где maxI задан перед началом цикла и равняется 13-и при каждом i выполняется свой запрос

и при каждом i выполняется свой порядок и свои значения из запросов. Далее создаются файлы, они немного разные по расположению и наполнению ячеек.

Т.е если i=1, то выполнится 1 запрос, наполнение ячеек будет происходить на основе цикла while, который в свою очередь по условию i запихнёт значение в определённые значения и после создастся определённый файл исходя из i.

Сейчас выглядит так:
Код:
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
maxI:=13;
for i := 1 to maxI do
begin
  if i = 1 then
  dm.zapros.SQL.Text := 'запрос1'
  else if
  if i = 2 then
  dm.zapros.SQL.Text := 'запрос2'
  else if
  if i = 3 then
  dm.zapros.SQL.Text := 'запрос3';
  //И так 13 запросов
   
  dm.zapros.Open;
  if  not dm.zapros.IsEmpty then
    begin
      try
        Exsel := CreateOleObject('Excel.Application');
        Exsel.DisplayAlerts := false;
        WorkBook := Exsel.Workbooks.Add;
        Sheet := WorkBook.WorkSheets[1];
        r:=1;
 
        while not dm.zapros.Eof do
        begin
 
          if (i in [1,2,3,4,5,6,7,8,9,10,11,12,13] then
            begin
               Sheet.Cells[r,1].Value := dm.zapros.FieldByName('path').AsString;
               Sheet.Cells[r,2].Value := dm.zapros.FieldByName('kol').AsInteger;
            end;
 
          if (i in [1,2,8,11,12,13]) then
            begin
              Sheet.Cells[r,5].Value := dm.zapros.FieldByName('E').AsInteger;
            end;
 
          if (i in [3,4,7,9,10]) then
            begin
              Sheet.Cells[r,4].Value:=dm.zapros.FieldByName('E').AsInteger;
            end;
 
          if (i in [9,10]) then
            begin
              Sheet.Cells[r,7].Value := dm.zapros.FieldByName('F').AsString;
            end;
 
          if (i in [1,10,12,13]) then
            begin
              Sheet.Cells[r,6].Value := dm.zapros.FieldByName('F').AsString;
            end;
 
          if (i in [5,6]) then
            begin
              Sheet.Cells[r,6].Value := dm.zapros.FieldByName('G').AsString;
            end;
 
          if (i in [1,2,4,13]) then
            begin
              Sheet.Cells[r,7].Value := dm.zapros.FieldByName('G').AsString;
            end;
 
          if (i in [9,10,]) then
            begin
              Sheet.Cells[r,8].Value := dm.zapros.FieldByName('G').AsString;
            end;
          inc(r);
          dm.aqLoc.Next;
        end;
      finally
        case i of
          1: WorkBook.SaveAs(Tempkp+'\файл1 от '+dt+'.csv',6);
          2: WorkBook.SaveAs(Tempkp+'\файл2 от '+dt+'.csv',6);
          3: WorkBook.SaveAs(Tempkp+'\файл3 от '+dt+'.csv',6);
          //и так 13 файлов
          
 
        end;
        WorkBook.Close;
        Exsel.Application.Quit;
        Exsel := Unassigned;
      end;
    end;
 
 
 
end;
Собсно говоря меня интересует цикл while. Поверьте, прежний вид был куда хуже, что-то из разряда "тронул листик - всё дерево упало".

Хотелось бы поинтересоваться, Что с этим можно сделать, чтобы увеличить возможность воздействия на этот цикл, его переделки, добавления чего-то нового без применения костылей?
Ответить с цитированием