Форум программистов, компьютерный форум, киберфорум
Наши страницы
Jlovenpk1
Войти
Регистрация
Восстановить пароль
Оценить эту запись

C# Window Forms DataGridview заполнение и удаление клонов

Запись от Jlovenpk1 размещена 19.12.2018 в 08:41

Привет читатель моего скромного блога, пишу я сюда редко, но в основном я храню тут свои заметки на те вещи, которые точно не буду запоминать и использую редко.
В будущем надеюсь закончить проект и написать большую статью о GMap, как его модифицировать, о своих модификациях напишу, о кликабельных домах, но пока вернемся к основной теме.

DataGridView - много решений, разных решений, по этому не побоюсь если кто-то сделать code - review и укажет на лучшие способы, я буду только благодарен.

И так, я выгружаю данные из базы.

C#
1
2
3
4
5
6
7
8
preLoad = new Load_Grid(); // эт мой недокласс подключения
            //FindingPoint(); // в будущем расскажу об этом
            //ParsingExcel(); // для парсинга экселя, так же в будущем расскажу зачем это 
            preLoad.Connect(); // коннект к базе
            preLoad.Select(@"SELECT information.ID, object.adres, trouble, type_trouble, size,date 
                                                      FROM gissystem.information
                                                      inner join gissystem.object
                                                      where Object = object.ID;"); // делаем запрос
Получив ответ и данные едем к основной теме, среди полученных данных есть повторение адресов, которые мне нужно объединять и выводить новую инфу - Количество аварий на адресе.

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
while(preLoad.dataRead.Read())
            {
                ViewGrid.Rows.Add();
                ViewGrid.Rows[index].Cells[0].Value = preLoad.dataRead[0].ToString();
                ViewGrid.Rows[index].Cells[1].Value = preLoad.dataRead[1].ToString();
                ViewGrid.Rows[index].Cells[2].Value = preLoad.dataRead[2].ToString();
                ViewGrid.Rows[index].Cells[3].Value = preLoad.dataRead[3].ToString();
                ViewGrid.Rows[index].Cells[4].Value = preLoad.dataRead[4].ToString();
                ViewGrid.Rows[index].Cells[5].Value = preLoad.dataRead[5].ToString();
                ViewGrid.Rows[index].Cells[6].Value = 1;
                index++;
              
             }
            for (int i = 0; i < ViewGrid.RowCount;i++)
            {
                for (int j = 1; j < ViewGrid.RowCount; j++)
                {
                    string check_ = ViewGrid.Rows[i].Cells[1].Value.ToString();
                    string check__ = ViewGrid.Rows[j].Cells[1].Value.ToString();
                    string checkid = ViewGrid.Rows[i].Cells[0].Value.ToString();
                        string checkid_ = ViewGrid.Rows[j].Cells[0].Value.ToString();
                    if (ViewGrid.Rows[i].Cells[1].Value.ToString() == ViewGrid.Rows[j].Cells[1].Value.ToString() && 
                                                                        ViewGrid.Rows[i].Cells[0].Value.ToString() != ViewGrid.Rows[j].Cells[0].Value.ToString())
                    {
                        int count = int.Parse(ViewGrid.Rows[i].Cells[6].Value.ToString());
                        ViewGrid.Rows[i].Cells[2].Value += " "+ViewGrid.Rows[j].Cells[2].Value.ToString();
                        ViewGrid.Rows[i].Cells[3].Value += " "+ViewGrid.Rows[j].Cells[3].Value.ToString();
                        ViewGrid.Rows[i].Cells[4].Value += " "+ViewGrid.Rows[j].Cells[4].Value.ToString();
                        ViewGrid.Rows[i].Cells[5].Value += " "+ViewGrid.Rows[j].Cells[5].Value.ToString();
                        ViewGrid.Rows[i].Cells[6].Value = count + 1;
                        ViewGrid.Rows.RemoveAt(j);
 
                        ViewGrid.Refresh();
                        j = 0;
                        if (ViewGrid.Rows[i].Cells[6].Value.ToString() == "4")
                        {
                            ViewGrid.Rows[i].DefaultCellStyle.BackColor = Color.DarkRed;
                        }
                        else
                            if (ViewGrid.Rows[i].Cells[6].Value.ToString() == "2")
                        {
                            ViewGrid.Rows[i].DefaultCellStyle.BackColor = Color.DarkOrange;
                        }
                    }
                    if (ViewGrid.Rows[i].Cells[6].Value.ToString() == "1")
                    {
                        ViewGrid.Rows[i].DefaultCellStyle.BackColor = Color.DarkGreen;
                    }
                }
                
            }
Вот такой здоровый кусок кода получаем, он еще крехтит - пыхтит и его скорость мне не нравится на 100 строк, боюсь представить если строк будет 50 000 тысяч.
Да под это дело можно написать тест и точно проверить скорость работы, руки пока не дошли, сроки жмут.

Буду рад комментариям с поправками для кода и способами ускорить и улучшить код х)

Всех с наступающим годом
Размещено в Без категории
Просмотров 168 Комментарии 0
Всего комментариев 0
Комментарии
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.
Рейтинг@Mail.ru