Аватар для ikage
5 / 5 / 0
Регистрация: 26.06.2012
Сообщений: 78

Занести сумму столбцов каждого столбца DbGrid в свой Edit

17.01.2013, 23:23. Показов 709. Ответов 5

Студворк — интернет-сервис помощи студентам
доброе всем время суток.
написал код для вывода суммы столбца в tdit.столбцов 6 и соответственно 6 едитов.
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
var
i:integer;
 
begin
dbgrid1.DataSource.dataset.first;
i:=0;
while not dbgrid1.datasource.dataset.eof do
begin
i:=i+dbgrid1.datasource.dataset.fieldbyname('один').asinteger;
dbgrid1.datasource.dataset.next;
 
edit1.text:=inttostr(i);
end;
подскажите как можно его упростить чтоб из-за одной строки
Delphi
1
i:=i+dbgrid1.datasource.dataset.fieldbyname('один').asinteger;
шесть раз не переписывать всё выше написанное.в данной строке длжно меняется только имя столбца(один,два,три и.т.д)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
17.01.2013, 23:23
Ответы с готовыми решениями:

Посчитать сумму столбцов двухмерного массива и вывести сумму каждого столбца в одномерный массив
Посчитать сумму столбцов двухмерного массива и вывести сумму каждого столбца в одномерный массив. Мне считает сумму первого столбца и...

Создать таблицу. Задать количество столбцов и строк. Посчитать по отдельности каждого столбца сумму
Приветствую Форумчани. Создал таблицу с помощью компонента СтринГрид. Все работает. Задаю количество столбцов и строк все выполняется....

Определить сумму элементов каждого столбца матрицы и упорядочить номера столбцов по убыванию значений
Здравствуйте!помогите мне пожалуйста(( Дана квадратная матрица размером n x n, содержащая вещественные числа. Определить сумму элементов...

5
 Аватар для Andrys74
217 / 81 / 6
Регистрация: 23.04.2012
Сообщений: 340
18.01.2013, 08:22
Не самый лучший вариант:
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
var
i1,i2,i3,i4,i5,i6:integer;
 
begin
dbgrid1.DataSource.dataset.first;
i1:=0;
i2:=0;
i3:=0;
i4:=0;
i5:=0;
i6:=0;
while not dbgrid1.datasource.dataset.eof do
begin
i1:=i1+dbgrid1.datasource.dataset.fieldbyname('один').asinteger;
i2:=i2+dbgrid1.datasource.dataset.fieldbyname('два').asinteger;
i3:=i3+dbgrid1.datasource.dataset.fieldbyname('три').asinteger;
i4:=i4+dbgrid1.datasource.dataset.fieldbyname('четыре').asinteger;
i5:=i5+dbgrid1.datasource.dataset.fieldbyname('пять').asinteger;
i6:=i6+dbgrid1.datasource.dataset.fieldbyname('шесть').asinteger;
dbgrid1.datasource.dataset.next;
 
edit1.text:=inttostr(i1);
edit2.text:=inttostr(i2);
edit3.text:=inttostr(i3);
edit4.text:=inttostr(i4);
edit5.text:=inttostr(i5);
edit6.text:=inttostr(i6);
end;
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33421 / 21527 / 8240
Регистрация: 22.10.2011
Сообщений: 36,935
Записей в блоге: 12
18.01.2013, 12:32
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
var
   i : integer;
   arrEdit : array[1 .. 6] of TEdit;
const 
   names : array[1 .. 6] of string = 
   ('один', 'два', 'три', 'четыре', 'пять', 'шесть');
 
begin
   for i := 1 to 6 do 
   begin
      arrEdit := (FindComponent(Format('Edit%d', [i])) as TEdit);
      arrEdit[i].Tag := 0;
   end;
 
   dbgrid1.DataSource.dataset.first;  
   while not dbgrid1.datasource.dataset.eof do
   begin
      for i := 1 to 6 do
      begin
         arrEdit[i].Tag := arrEdit[i].Tag + dbgrid1.datasource.dataset.fieldbyname(names[i]).asinteger;
         arrEdit[i].text := inttostr(arrEdit[i].Tag); // Это можно делать и после окончания главного цикла, один раз
      end;
      dbgrid1.datasource.dataset.next;
   end;
end;
1
 Аватар для ikage
5 / 5 / 0
Регистрация: 26.06.2012
Сообщений: 78
19.01.2013, 13:21  [ТС]
Цитата Сообщение от UI Посмотреть сообщение
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
var
   i : integer;
   arrEdit : array[1 .. 6] of TEdit;
const 
   names : array[1 .. 6] of string = 
   ('один', 'два', 'три', 'четыре', 'пять', 'шесть');
 
begin
   for i := 1 to 6 do 
   begin
      arrEdit := (FindComponent(Format('Edit%d', [i])) as TEdit);
      arrEdit[i].Tag := 0;
   end;
 
   dbgrid1.DataSource.dataset.first;  
   while not dbgrid1.datasource.dataset.eof do
   begin
      for i := 1 to 6 do
      begin
         arrEdit[i].Tag := arrEdit[i].Tag + dbgrid1.datasource.dataset.fieldbyname(names[i]).asinteger;
         arrEdit[i].text := inttostr(arrEdit[i].Tag); // Это можно делать и после окончания главного цикла, один раз
      end;
      dbgrid1.datasource.dataset.next;
   end;
end;
в строке
Delphi
1
arrEdit := (FindComponent(Format('Edit%d', [i])) as TEdit);
ругается на [Error] Unit3.pas(298): Incompatible types: 'Array' and 'TEdit'
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33421 / 21527 / 8240
Регистрация: 22.10.2011
Сообщений: 36,935
Записей в блоге: 12
19.01.2013, 13:38
Ну да, набирал прямо здесь, без проверки. Строка должна выглядеть так:
Delphi
1
arrEdit[i] := (FindComponent(Format('Edit%d', [i])) as TEdit);
0
 Аватар для ikage
5 / 5 / 0
Регистрация: 26.06.2012
Сообщений: 78
19.01.2013, 19:00  [ТС]
спасибо за ответы.всё работает
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.01.2013, 19:00
Помогаю со студенческими работами здесь

Вычислить сумму средних арифметических элементов каждого столбца массив С, содержащего m столбцов по n чисел в каждом
Вычислить сумму средних арифметических элементов каждого столбца массив С, содержащего m столбцов по n чисел в каждом.

Определить сумму элементов каждого столбца левой половины и сумму элементов каждого четного столбца правой половины матрицы А.
Матрица A (М кратно 4) разделена по вертикали на две поло¬вины. Определить сумму элементов каждого столбца левой половины и сумму элементов...

Определить сумму элементов каждого столбца левой половины и сумму элементов каждого четного столбца правой половины матрицы A
Матрица A (M кратно 4) разделена по вертикали на две половины. Определить сумму элементов каждого столбца левой половины и сумму элементов...

Найти сумму положительных элементов каждого четного столбца и произведение отрицательных элементов каждого нечетного столбца
Дана матрица А(5,6). Найти сумму положительных элементов каждого четного столбца и произведение отрицательных элементов каждого нечетного...

Вычислить суммы элементов каждого столбца матрицы, и занести их в одномерный массив
Всем привет! помогите плз написать программу для ввода элементов двумерного массива, вывода этого массива на экран. Вычислить суммы...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
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