Форум программистов, компьютерный форум, киберфорум
Visual Basic .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/15: Рейтинг темы: голосов - 15, средняя оценка - 4.60
26 / 26 / 6
Регистрация: 09.09.2015
Сообщений: 155

Группировка и суммирование строк в DataTable

24.11.2016, 17:26. Показов 3304. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет всем, для группировки и суммирования строк в DataTable я использую такую функцию
но мне кажется что я делаю не правильно, можете предложить другой вариант??

VB.NET
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
   Dim restb As DataTable = CollapseDT(targetDT, "Склад,Товар", "Сумма")
 
   Public Function CollapseDT(target As DataTable, group As String, summ As String) As DataTable
        Dim returnDT As New DataTable("Collapse")
        Dim mgroups() As String = group.Split(",")
        For Each groupitem As String In mgroups
            returnDT.Columns.Add(Trim(groupitem))
        Next
        Dim msumm() As String = summ.Split(",")
        For Each summitem As String In msumm
            returnDT.Columns.Add(Trim(summitem))
        Next
 
        For Each row As DataRow In target.Rows
            If row.RowState = DataRowState.Deleted Then
                Continue For
            End If
            Dim find As Integer = 0
            Dim findrow As DataRow = Nothing
            For Each row2 As DataRow In returnDT.Rows
                find = 0
                For Each groupitem As String In mgroups
                    If row2(groupitem) = row(groupitem) Then
                        If find = 0 Then
                            find = 1
                        End If
                    Else
                        find = 2
                    End If
                Next
                If find = 1 Then
                    findrow = row2
                    Exit For
                End If
            Next
            If find = 1 Then
                For Each summitem As String In msumm
                    findrow(summitem) += row(summitem)
                Next
            Else
                findrow = returnDT.NewRow
                For Each groupitem As String In mgroups
                    findrow(groupitem) = row(groupitem)
                Next
                For Each summitem As String In msumm
                    findrow(summitem) = row(summitem)
                Next
                returnDT.Rows.Add(findrow)
            End If
        Next
        Return returnDT
    End Function
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
24.11.2016, 17:26
Ответы с готовыми решениями:

Группировка и суммирование datatable
Всем привет. Как можно выбрать данные из datatable, аналогично sql запросу ""SELECT Поле1, AVG(Поле2) FROM " На выходе...

GroupBy DataTable: группировка и суммирование столбцов
Доброго времени суток. Мне нужно для каждого ID просуммировать все столбцы в таблице: все вроде просто, но что не работает. Я делаю вот...

Группировка строк DataTable с использованием LINQ
Всем привет! Linq не занимался толком. Возникла такая задача. Есть DataTable table2. У неё 18 колонок из которых по 16 надо сделать...

1
4708 / 3661 / 857
Регистрация: 02.02.2013
Сообщений: 3,518
Записей в блоге: 2
24.11.2016, 20:19
Попробуйте так:
Группировка по полю CategoryID + соответствующие суммы по полю UnitPrice
VB.NET
1
2
3
Dim ProductDT As DataTable = DS.Tables(tbProd)
Dim rr = From prod In ProductDT Group prod By prod!CategoryID Into catGR = Group Select CategoryID, csum = catGR.Sum(Function(p) CDbl(p!UnitPrice))
DataGridView2.DataSource = rr.ToArray
Группировка по двум полям CategoryID и SupplierID + соответствующие суммы по полю UnitPrice
VB.NET
1
2
Dim rr = From prod In ProductDT Group prod By prod!CategoryID, prod!SupplierID Into catGR = Group Select CategoryID, SupplierID, csum = catGR.Sum(Function(p) CDbl(p!UnitPrice))
DataGridView2.DataSource = rr.ToArray
3
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.11.2016, 20:19
Помогаю со студенческими работами здесь

Группировка и суммирование значений строк DataGridView
У меня есть DataGridView на форме, в нем есть определенные строки, в которых например ид, название и цена. Как мне сгруппировать все...

Группировка данных в DataTable
Добрый день! Помогите, пожалуйста, разобраться с запросом LINQ. Может я вообще использую не тот инструмент. Цель: сколько...

Суммирование и группировка
Есть три таблицы(материалы, объекты, поставки) скрины: . Нужно из таблицы поставки суммировать кол-во поставок по материалам и запихать...

Запрос, Группировка, Суммирование
Добрый день всем!!! У меня такая задача, не могу разбираться, помогите пожалуйста: есть Table1, баллы студентов по категориями...

Группировка (суммирование) статданных
Здравствуйте, форумчане! Подскажите пожалуйста, что мне нужно сделать, чтобы правильно подсчитывались данные в запросе (суммирует...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru