Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
 Аватар для ikage
5 / 5 / 0
Регистрация: 26.06.2012
Сообщений: 78

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

17.01.2013, 23:23. Показов 690. Ответов 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
33374 / 21499 / 8235
Регистрация: 22.10.2011
Сообщений: 36,894
Записей в блоге: 11
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
33374 / 21499 / 8235
Регистрация: 22.10.2011
Сообщений: 36,894
Записей в блоге: 11
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
Ответ Создать тему
Новые блоги и статьи
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru