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

Найти ячейки со значениями в DataGridView

16.04.2017, 11:32. Показов 3543. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В DataGridView требуется найти все ячейки, заполненные значениями кроме верхних ячеек со значениями.
Миниатюры
Найти ячейки со значениями в DataGridView  
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.04.2017, 11:32
Ответы с готовыми решениями:

Изменение содержимого одной ячейки Datagridview после изменения другой ячейки
Здравствуйте. Есть Datagridview с 2 столбцами. Столбцы типа ComboBox. В 1 столбце уже забиты значения, 2 столбец пустой. Необходимо сделать...

Форматирование ячейки в dataGridView. Как поменять цвет определенной ячейки
Хочу поменять цвет выбранной ячейки, так что бы когда при выбраной строки цвет ячейки оставался таким же. Пример: Что бы дата...

При выделении ячейки в DataGridView контрол перемещается и становится по правую сторону ячейки
Всем доброе утро. В приложении есть DataGridView и контрол со всеми функциями по управлению данными в DataGridView. При выделении ячейки...

10
Почетный модератор
Эксперт С++
 Аватар для SatanaXIII
5851 / 2862 / 392
Регистрация: 01.11.2011
Сообщений: 6,906
17.04.2017, 11:13
C#
1
2
3
4
5
List<DataGridViewCell> DGVCList = new List<DataGridViewCell>();
dataGridView1.SelectAll();
foreach (DataGridViewCell dgvc in dataGridView1.SelectedCells)
    if (!dgvc.Value.Equals(string.Empty))
        DGVCList.Add(dgvc);
0
64 / 55 / 30
Регистрация: 30.12.2015
Сообщений: 166
17.04.2017, 11:18
avk561,
C#
1
2
3
4
5
6
7
8
for(int i = 0, i < dataGridView1.Columns.Count,i++)
{
for(int j = 4, i < dataGridView1.Rows.Count,i++)//тут указываем с какой строки начинать.
{
if(dataGridView1.Rows[j].Cells[i].Value != String.Empty)//это для текстовый ячеек.
{//а тут уже делаешь что тебе надо}
}
}
Писал без студии, так что могут быть ошибки, сорян)
0
0 / 0 / 0
Регистрация: 30.07.2016
Сообщений: 26
17.04.2017, 21:16  [ТС]
Спасибо, коды работают, но уточню, найти все ячейки со значениями кроме верхних ячеек со значениями (на рисунке они обозначены), рисунок- как условный образец.
0
Почетный модератор
Эксперт С++
 Аватар для SatanaXIII
5851 / 2862 / 392
Регистрация: 01.11.2011
Сообщений: 6,906
18.04.2017, 08:47
Цитата Сообщение от avk561 Посмотреть сообщение
кроме верхних
Кроме верхних четырех? Именно прям четыре строки сверху пропустить. Не пять, не три, не пропорционально размеру таблицы, а ровно четыре строки, да?
0
Эксперт .NET
 Аватар для Даценд
5878 / 4755 / 2939
Регистрация: 20.04.2015
Сообщений: 8,361
18.04.2017, 09:09
Лучший ответ Сообщение было отмечено avk561 как решение

Решение

avk561,
C#
1
2
3
4
5
6
7
8
9
10
11
12
List<DataGridViewCell> DGVCList = new List<DataGridViewCell>();
for(int i=0; i<dataGridView1.ColumnCount; i++)
{
    bool firstFound = false;
    for(int j=0; j<dataGridView1.RowCount; j++)
    {
        if (dataGridView1[i, j].Value!=null && !dataGridView1[i, j].Value.Equals(string.Empty) && !firstFound)
            firstFound = true;
        else if (dataGridView1[i, j].Value != null && !dataGridView1[i, j].Value.Equals(string.Empty) && firstFound)
            DGVCList.Add(dataGridView1[i, j]);
    }
}
1
18.04.2017, 10:16

Не по теме:

Цитата Сообщение от Даценд Посмотреть сообщение
dataGridView1[i, j].Value!=null
Я честно сказать не смог добиться поведения, чтобы было равно null. Но скорее всего просто плохо старался.

0
64 / 55 / 30
Регистрация: 30.12.2015
Сообщений: 166
18.04.2017, 10:44
avk561, в моём примере подсчёт начинается с пятой строки, если надо начинать с какой другой, просто измени значение переменной j.
0
Эксперт .NET
 Аватар для Даценд
5878 / 4755 / 2939
Регистрация: 20.04.2015
Сообщений: 8,361
18.04.2017, 14:59
Цитата Сообщение от SatanaXIII Посмотреть сообщение
не смог добиться поведения, чтобы было равно null
Да запросто!
Миниатюры
Найти ячейки со значениями в DataGridView  
0
0 / 0 / 0
Регистрация: 30.07.2016
Сообщений: 26
18.04.2017, 20:36  [ТС]
Рисунок для наглядного представления. Ячейки могут быть заполнены любые. Найти все ячейки в каждой колонке со значениями, кроме верхних заполненных ячеек в каждой колонке!

Добавлено через 3 минуты
а если без List? И строка 10 что означает?

Добавлено через 3 минуты
Находит только верхние заполненные ячейки:
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
  private DataGridView DGV1 = new DataGridView();
   private string ЩО = "ЩО";
 private void button5_Click(object sender, EventArgs e)
        {
                    int nCols = DGV1.ColumnCount;// число колонок
                    int nRows = DGV1.RowCount;// число строк 
         
                    for (Int32 i = 0; i < nCols; i++)
                    {
                        for (int j = 0; j < nRows; j++)
                        {
                            var D = DGV1[i, j];//матрица        
                            var ТипЩитка = D.FormattedValue;// текст в ячейке
                           
                            if (String.Equals(ТипЩитка, ЩО))
                            {
                              //  MessageBox.Show("№ ячейки со значением ЩО:" + j);
                            }                
 
                            if (D.Value != null)// если ячейка заполнена значением
                            {
                                j = DGV1.RowCount;// число строк, заполненых значениями                               
                               
                            }
                     
                        }
                    }
Добавлено через 10 минут
Да работает ! Спс!
0
0 / 0 / 0
Регистрация: 30.07.2016
Сообщений: 26
09.03.2018, 14:48  [ТС]
А как найти все нижние ячейки со значениями в колонках?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
09.03.2018, 14:48
Помогаю со студенческими работами здесь

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

SelectChange внутри ячейки DataGridView. Вернуть Выделенный текст внутри редактируемой ячейки
Собсна, пишу HexEditor на основе таблицы в WindowsForm. Сколько не бился, MSDN говорит, что DataGridView не имеет событий на...

Сортировка DatagridView двумя значениями
У меня есть DatagridView заполненный значениями. В нём есть поле DataPosecheniya. Ещё есть 2 TextBox для сортировки в которые я ввожу дату....

Заполнение DataGridView рандомными значениями
Добрый вечер, у меня возникла проблема с решением одной задачи. Так вот, у меня есть элемент DataGridView c оформленными строками и...

Столбец с уникальными значениями в DataGridView
Подскажите как сделать столбец с первичными ключами т.е если я например редактирую ячейку этого столбца и его значения совпадают со...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
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 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru