Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
0 / 0 / 0
Регистрация: 06.07.2013
Сообщений: 3

Ошибка при поиске в DataGridView

06.07.2013, 14:42. Показов 1353. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!
Подскажите, пожалуйста, если кто знает.
У меня при повторном поиске в datagridview появляется ошибка о том, что "индексу не присвоено значение".
Поиск реализую так:
C#
1
2
3
4
5
6
7
8
for (int i = 0; i < dataGridView1.RowCount; i++)
            {
                if (dataGridView1[a, i].Value.ToString().Contains(b.Text) == false)
                {
                    dataGridView1.Rows.RemoveAt(i);
                    i = i - 1;
                }
            }
При запуске нового поиска содержимое dataGridView обновляется:
C#
1
2
this.tbl_MainTableAdapter.Fill(this.patientDataSet.tbl_Main);
            dataGridView1.Refresh();
Если в столбце найдено N совпадений, то сообщение об ошибке говорит, что "индексу N не присвоено значение". Видимо, я где-то ссылаюсь на уже несуществующую ячейку?
В обратном направлении цикл уже тоже пускала, проблема та же.
(b - это Textbox).
Заранее спасибо.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.07.2013, 14:42
Ответы с готовыми решениями:

Поиск по DataGridView. Ошибка при поиске по одному из полей
Помогите пожалуйста есть программа, на форме 3 организовал поиск по DataGridView по вводу данных в textBox. При вводе фамилии, имя, и...

NullReferenceException при поиске в DataGridView
Есть вот такой код - Когда я ввожу какие-либо данные в textbox, чтобы произвести поиск с выделением, то у меня выдает ошибку (ошибка на...

Изменение цвета при поиске в DataGridView
Есть поиск private void textBox1_TextChanged(object sender, EventArgs e) { { if...

4
0 / 0 / 0
Регистрация: 06.07.2013
Сообщений: 3
08.07.2013, 23:27  [ТС]
Проблему я не решила, но, если кто-то с такой столкнется, расскажу, как обошла ее.
Событие при нажатии кнопки "Поиск" теперь вызывает новую форму с новым datagridview, здесь и происходит удаление ненужных строк.

И еще, чтоб не менять в цикле значение счетчика вручную, отдельно выполняется поиск индексов строк которые надо удалить и отдельно цикл удаления этих строк.
0
 Аватар для Kruds
708 / 708 / 226
Регистрация: 04.03.2013
Сообщений: 1,384
09.07.2013, 13:57
Воспользуйтесь BindingSource и его свойством Filter. Не придется кошмарить грид.
1
 Аватар для pincet
1654 / 1153 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
09.07.2013, 18:31
Прямой поиск (LINQ)
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
    private void Find(string obj)
        {
                       
            if ((int)this.Columns[this.CurrentCell.ColumnIndex].Tag == 1)
            #region TextBox
            {
                var res = from DataGridViewRow c in this.Rows
                          where String.Compare(obj, 0, c.Cells[this.CurrentCell.ColumnIndex].Value.ToString(), 0, obj.Length) == 0
                          select c;
                if (!res.Any())
                    CanGoOn = false;                    
                else
                {
                    CurrentCell = this[CurrentCell.ColumnIndex, res.First().Index];
                    CanGoOn = true;
                }
            }
            #endregion
            else
            #region ComboBox
            {
                DataGridViewComboBoxColumn DGVCBC = (DataGridViewComboBoxColumn)this.Columns[this.CurrentCell.ColumnIndex];
 
                var res = from c in ((DataTable)DGVCBC.DataSource).AsEnumerable()
                          where string.Compare(obj, 0, c.Field<string>(DGVCBC.DisplayMember.ToString()), 0, obj.Length) == 0
                          select c.Field<int>(DGVCBC.ValueMember.ToString());
                if (!res.Any())
                    CanGoOn=false;
                else
                {
                    var res1 = from DataGridViewRow c in this.Rows
                               where !c.Cells[this.CurrentCell.ColumnIndex].Value.Equals(DBNull.Value) &&
                               res.Contains((int)c.Cells[this.CurrentCell.ColumnIndex].Value)
                               select c;
                    if (!res1.Any())
                        CanGoOn = false;
                    else
                    {
                        CurrentCell = this[CurrentCell.ColumnIndex, res1.First().Index];
                        CanGoOn = true;
                    }
                }
            }
            #endregion
            
        }
1
0 / 0 / 0
Регистрация: 06.07.2013
Сообщений: 3
09.07.2013, 19:22  [ТС]
Спасибо.
Еще один удобный вариант: поиск реализовать в хранимой процедуре и просто ее вызывать.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
09.07.2013, 19:22
Помогаю со студенческими работами здесь

Переход к первой строке при поиске по datagridview
Ребят, помогите пожалуйста. Много где уже искала, но так толком ничего и не нашла. У меня есть вот такой код для поиска: for (int i =...

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

Ошибка при поиске
Записал макрос, код даже не трогал, при попытке запуска выдает ошибку Run time error '91': Object variable or with block variable not...

Ошибка при поиске
Добрый вечер! В базе использую код для фильтрации (автор Capi), все работало прекрасно, пока фильтровалось в главной форме. Потом...

Ошибка при поиске в БД
Поиск по имени работает. А вот поиск по столбцу название которого состоит из двух слов не работает. В чем тут ошибка? procedure...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью 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