Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 1
Регистрация: 13.01.2013
Сообщений: 34

Цикл внутри цикла!

19.05.2014, 17:49. Показов 1096. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Имеется БД из 2 таблиц. Подключена к программе через АДО. Нужно вывести отчет в ексель по группам: т.е. сначала вывести название группы, после все данные связанные с этой группой. Написал все это, но почему то первый цикл не очень хорошо обрабатывается, с первой записи перескакивает сразу на последнюю. Код прилагаю:
C++
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
void __fastcall TGlav::Button1Click(TObject *Sender)
{
Glav->ADOTzapisi->Sort="Группа"  " ASC";
 
AnsiString sFile;
sFile = GetCurrentDir()+"\\Печать.xlt";
 
 Variant App;
if(!fStart)
 {
 try
 {
App = Variant::CreateObject("Excel.Application");
fStart=true;
 }
 catch(...)
 {
 MessageBox(0, "Ошибка при открытии сервера",
 "Внимание", MB_OK);
 return;
 }
 }
 
Variant XLBook = App.OlePropertyGet("WorkBooks");
 
Variant Sh;
Procedure Open("Open");
XLBook.Exec(Open<<sFile);
Sh = XLBook.OlePropertyGet("Count");
Sh = App.OlePropertyGet("WorkSheets",1);
 
App.OlePropertySet("Visible",Variant(true));
 
String Str;
String Str2;
String Str3;
int i;
int index;
index=4;
Glav->ADOTgruppy->First();
for(i=1;i<=Glav->ADOTgruppy->RecordCount;i++)
 {String Grup;
  String Grupp;
 
  Grupp = Glav->ADOTgruppy->Fields->Fields[1]->AsString;
  Grup = Glav->ADOTgruppy->Fields->Fields[0]->AsString;
  Sh.OlePropertyGet("Cells",index,2).OlePropertySet("Value",Grupp.c_str());
 
  int x;
  AnsiString ran;
  index=index+1;
  Glav->ADOTzapisi->First();
  for(x=1;x<=Glav->ADOTzapisi->RecordCount;x++)
   {
    if (Glav->ADOTzapisi->Fields->Fields[1]->AsString=="True" && Glav->ADOTzapisi->Fields->Fields[3]->AsString==Grup)
    {
     Str = Glav->ADOTzapisi->Fields->Fields[1]->AsString;
     Str2 = Glav->ADOTzapisi->Fields->Fields[2]->AsString;
     Str3 = Glav->ADOTzapisi->Fields->Fields[4]->AsString;
 
     Sh.OlePropertyGet("Cells",index,2).OlePropertySet("Value",Str.c_str());
     Sh.OlePropertyGet("Cells",index,3).OlePropertySet("Value",Str2.c_str());
     Sh.OlePropertyGet("Cells",index,4).OlePropertySet("Value",Str3.c_str());
     Sh.OlePropertyGet("Cells",index,5).OlePropertySet("Value",Grup.c_str());
 
     ran="B4:D"+IntToStr(index);
     Sh.OlePropertyGet("Range",ran.c_str()).OlePropertyGet("Borders",9).
         OlePropertySet("LineStyle",1);
     Sh.OlePropertyGet("Range",ran.c_str()).OlePropertyGet("Borders",9).
         OlePropertySet("Weight",2);
     Sh.OlePropertyGet("Range",ran.c_str()).OlePropertyGet("Borders",9).
         OlePropertySet("ColorIndex",1);
 
     index=index+1;
     }
    Glav->ADOTzapisi->Next();
   }
  index=index+1;
  Glav->ADOTgruppy->Next();
 }
}
Прошу помощи!! Что может быть неправильно написано? Заранее спасибО!

Добавлено через 6 минут
Результат тоже выкладываю!
Миниатюры
Цикл внутри цикла!  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
19.05.2014, 17:49
Ответы с готовыми решениями:

Цикл For. Вывод цикла внутри цикла
Всем привет, есть проблемка. Код рабочий но при вводе среднего бала допустим выше несуществующего выдаёт 5 раз &quot;Таковых нет&quot;....

Цикл if внутри цикла for
Добрый день всем сюда зашедшим, пишу код на Pascal для программы isis/base возник вопрос, вот этот код отлично вынимает значения TRUE и...

Цикл внутри цикла
Здравствуйте, делаю скрипт для массового добавления урлов и кеев в базу тдс. Нужно чтобы переменная $poziciya увеличивалась на 1. То есть...

1
0 / 0 / 1
Регистрация: 13.01.2013
Сообщений: 34
20.05.2014, 11:03  [ТС]
Разобрался сам!! При проходе второго цикла курсор в Датасете "Группа" перемащался и ествественно становился на последнюю строчку, поэтому следующая и последующие записи были равны последне строчки. Добавил перед переходом на следующую строку первого цикла возврат на исходную строку в датасете.

C++
1
2
3
  TLocateOptions Options;
Options << loPartialKey << loCaseInsensitive;
Glav->ADOTgruppy->Locate("КодГруппы",Grup, Options);
Добавлено через 1 час 5 минут
и еще вопросик, мучаюсь с ним давно. Код работает отлично, но только один раз, при следующем нажатии на кнопку выходит ошибка, после перезапуска программы опять все работает и тоже только один раз. Ругается на строку:
C++
1
Variant XLBook = App.OlePropertyGet("WorkBooks");
Ошибка такая:
Миниатюры
Цикл внутри цикла!  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
20.05.2014, 11:03
Помогаю со студенческими работами здесь

Цикл внутри цикла
Есть вопрос, можно ли задать цикл внутри цикла? Вот в этой программе чтоб j прошёл условие while(j&lt;9) и выполнился цикл while (i&lt;9)...

Цикл внутри цикла
Возможно ли сделать ветвлением? Здесь же не одно истинное значение, как и ложное

Цикл внутри цикла (While)
Всем привет. Никак не получается организовать цикл внутри цикла на SQL Server 2012. В итоге отрабатывает только первый цикл. На...

Цикл внутри условия цикла
Можно ли внутрь условия засунуть цикл как показано ниже.Если да то что тут не так подскжите. Гугл не отвечал на мои запросы обращаюсь к...

Можно ли располагать цикл внутри цикла?
Здравствуйте. Можно ли располагать цикл внутри цикла? for(....) { if() { for(....) ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru