Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/21: Рейтинг темы: голосов - 21, средняя оценка - 4.62
0 / 0 / 0
Регистрация: 05.06.2015
Сообщений: 9

Сортировка столбца DataGridView

05.06.2015, 22:14. Показов 4276. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день, дорогие форумчане. прошу у вас помощи с сортировкой данных в столбце dataGridView. Данные в таблицу заносятся из файла *.CSV. Столкнулся с проблемой, что автоматическая сортировка выполняется по принципу сортировки строки, а нужно по принципу сортировки чисел. Не могли бы вы подсказать, как их сортировать, что бы число в дальнейшем соответствовало значению других полей. Буду премного признателен, если кто-то еще и код подкинет. заранее спасибо

Добавлено через 4 часа 42 минуты
Всем спасибо за внимание, нашел вариант решения самостоятельно. Віглядит не очень, но работает довольно быстро
Ниже прикреплю код. строго не судите, только учусь.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
double[] array1 = new double[kol_vo2];
            string[,] array2 = new string[kol_vo2, 5]; 
            for (int q = 0; q < kol_vo2; q++)
            {
                array1[q] = Convert.ToDouble(dataGridView1.Rows[q].Cells[5].Value);
                for (int w = 0; w < 5; w++)
                {
                    array2[q, w] = dataGridView1.Rows[q].Cells[w + 1].Value.ToString();
                }
            }
            Array.Sort(array1);
            for (int q = 0; q < kol_vo2; q++)
                for (int w = 0; w < kol_vo2; w++)
                    if (array1[q] == double.Parse(array2[w, 4]))
                    {
                        dataGridView1.Rows[q].Cells[1].Value = array2[w,0].ToString();
                        dataGridView1.Rows[q].Cells[2].Value = array2[w,1].ToString();
                        dataGridView1.Rows[q].Cells[3].Value = array2[w,2].ToString();
                        dataGridView1.Rows[q].Cells[4].Value = array2[w,3].ToString();
                        dataGridView1.Rows[q].Cells[5].Value = array2[w,4].ToString();
                        break;
                    }
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
05.06.2015, 22:14
Ответы с готовыми решениями:

Добавление нового столбца в DataGridView и в первую строку данного столбца добавление значения из textbox
Привет всем! Народ подскажите как мне сделать чтобы через кнопу Button добавлялся новый столбец в datagridview и в первую строку данного...

Автозаполнение столбца datagridview
Доброго времени суток :) Возникла проблема с datagridview. Суть в том что надо сделать чтобы столбец диаметр заполнялся автоматически при...

DataGridView индекс столбца
Отображена таблица sql в DataGridView . Как зная номер столбца присвоит тексту в textbox1 название это столбца.. т.е. есть таблица с...

3
 Аватар для Art
153 / 153 / 56
Регистрация: 20.12.2011
Сообщений: 1,614
06.06.2015, 09:32
Лучший ответ Сообщение было отмечено Asda1995 как решение

Решение

Asda1995, а вот это, или это не пробовали?
0
0 / 0 / 0
Регистрация: 05.06.2015
Сообщений: 9
06.06.2015, 13:12  [ТС]
Art, с тем, что было на MSDN я не очень разобрался, а вот что касается 2-ой ссылки, то там сортировка получилась не очень, так как столбец сортировался, а остальные не менялись местами, а это очень важно было
0
0 / 0 / 0
Регистрация: 05.06.2015
Сообщений: 9
11.06.2015, 12:02  [ТС]
Придумал новый метод сортировки, так как данный метод, при нахождение 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
void sort(int kolichestvo, int stolbec)
        {
            try
            {
                this.dataGridView1.DataSource = null;
                DataTable DT = new DataTable();
                DT.Columns.AddRange(new DataColumn[]
                {
                    new DataColumn("№", typeof(Int32)),
                    new DataColumn("Фамилия", typeof(String)),
                    new DataColumn("Имя", typeof(String)),
                    new DataColumn("Возраст (полный)", typeof(Int32)),
                    new DataColumn("Собственный вес", typeof(Double)),
                    new DataColumn("Первый подход", typeof(Double)),
                    new DataColumn("Второй подход", typeof(Double)),
                    new DataColumn("Третий подход", typeof(Double))
                });
                List<String> ListOfHeaderTextColumns = new List<String>();
                for (int i = 0; i < 7; i++)
                {
                    ListOfHeaderTextColumns.Add(this.dataGridView1.Columns[i].HeaderText);
                }
                for (int i = 0; i < kolichestvo; i++)
                {
                    DataRow NewRow = DT.NewRow();
                    NewRow.ItemArray = new object[] 
                    {  
                        Convert.ToInt32(this.dataGridView1[0, i].Value),
                        Convert.ToString(this.dataGridView1[1, i].Value), 
                        Convert.ToString(this.dataGridView1[2, i].Value), 
                        Convert.ToInt32(this.dataGridView1[3, i].Value),
                        Convert.ToDouble(this.dataGridView1[4, i].Value),
                        Convert.ToDouble(this.dataGridView1[5, i].Value),
                        Convert.ToDouble(this.dataGridView1[6, i].Value),
                        Convert.ToDouble(this.dataGridView1[7, i].Value)
                    };
                    DT.Rows.Add(NewRow);
                }
                this.dataGridView1.DataSource = null;
                DT = DT.AsEnumerable().OrderBy(row => row.Field<Double>(stolbec)).CopyToDataTable();
               for (int i = 0; i < kolichestvo; i++)
                {
                    for (int j = 1; j < 8; j++)
                        dataGridView1.Rows[i].Cells[j].Value = DT.Rows[i][j].ToString();
                } 
                this.dataGridView1.DataSource = null;
            }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.06.2015, 12:02
Помогаю со студенческими работами здесь

Сумма столбца datagridview
int sum = new int; for (int i = 4; i &lt;= tablekursDataGridView.ColumnCount; i++) { sum = 0; ...

Индекс столбца в DataGridView
При попытке получить индекс столбца через string выводит ошибку в следующем случае: (sender as DataGridView).Columns Однако с...

DataGridView ширина столбца
Добрый день! Есть DataGridView, данные берутся из БД. В DGW 6 столбцов. Ширину столбца я указываю через DataGridView.Columns.Width = 100;....

DataGridView - копирование столбца
Мне надо добавить столбец слева от выделенной ячейки. Делаю так: DataGridViewColumn dgvAdd =...

Из столбца datagridview в массив
Есть столбец в datagridview, в нем находятся числа типа double, нужно их все перевести в массив типа int. Пожалуйста помогите кто-нибудь!...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru