Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
 Аватар для SkYMaaN
25 / 19 / 9
Регистрация: 05.04.2019
Сообщений: 338

Исключение в DataGridView || Недопустимое значение DataGridViewComboBoxCell || Newtonsoft.JSON

19.02.2021, 04:46. Показов 1410. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброй ночи!
Есть объект типа DataGridView все столбцы которого типа DataGridViewComboBoxColumn.
После выбора пользователем необходимых значений в столбцах - данные из DataGridView записываются в объект типу System.Data.DataTable. А этот объект сериализуется в JSON строку. Вот функция сериализации:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
if (saveFileDialog.ShowDialog() == DialogResult.OK)
                {
                    DataTable dataTable = new DataTable();
                    for (int i = 0; i < (owner as MainForm).dataGridView2.Rows.Count - 1; i++)
                    {
                        dataTable.Rows.Add();
                        for (int j = 0; j < (owner as MainForm).dataGridView2.Columns.Count; j++)
                        {
                            dataTable.Columns.Add();
                            if ((owner as MainForm).dataGridView2.Rows[i].Cells[j].Value != null)
                            {
                                dataTable.Rows[i][j] = (owner as MainForm).dataGridView2.Rows[i].Cells[j].Value.ToString();
                            }
                        }
                    }
                    string JSONstring = Newtonsoft.Json.JsonConvert.SerializeObject(dataTable);
                    using (FileStream fs = new FileStream(saveFileDialog.FileName, FileMode.Create))
                    {
                        fs.Write(System.Text.Encoding.Default.GetBytes(JSONstring), 0, System.Text.Encoding.Default.GetBytes(JSONstring).Length);
                    }
                }
Загружается вновь успешно. Но при попытке наполнить пустой DataGridView все столбцы которого типа DataGridViewComboBoxColumn - многоразово возникает ошибка указанная на скриншоте, и в DataGridView заносится только пару значений.
DataGridView.DataSource = dataTable.DefaultView; не подходит в силу того, что столбцы вместо DataGridViewComboBoxColumn стают обычными текстовыми.
Вот функция загрузки ранее сериализованого в JSON объекта типа DataTable и последующей записи значений в DataGridView.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
DataTable dataTable = new DataTable();
                    using (FileStream fs = new FileStream(openFileDialog.FileName, FileMode.Open))
                    {
                        (owner as MainForm).dataGridView2.DataSource = null;
                        byte[] array = new byte[fs.Length];
                        fs.Read(array, 0, array.Length);
                        dataTable = Newtonsoft.Json.JsonConvert.DeserializeObject<System.Data.DataTable>(System.Text.Encoding.Default.GetString(array));
                    }                    
                    Program.ClearDataGridView(owner);
                    (owner as MainForm).dataGridView2.RowCount = dataTable.Rows.Count;
                    for (int i = 0; i < dataTable.Rows.Count;i++)
                    {
                        for(int j = 0; j < dataTable.Columns.Count; j++)
                        {
                            (owner as MainForm).dataGridView2.Rows[i].Cells[j].Value = dataTable.Rows[i][j].ToString();
                        }
                    }
Для сериализации/десериализации использую Newtonsoft.JSON
Не подскажете в чём проблема?
Миниатюры
Исключение в DataGridView || Недопустимое значение DataGridViewComboBoxCell ||  Newtonsoft.JSON   Исключение в DataGridView || Недопустимое значение DataGridViewComboBoxCell ||  Newtonsoft.JSON  
Вложения
Тип файла: txt DataTable.txt (740 байт, 2 просмотров)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
19.02.2021, 04:46
Ответы с готовыми решениями:

Исключение в DataGridView: System.ArgumentsException: Недопустимое значение DataGridViewComboBoxCell
Всем добрый день! Прошу совета. Код индусский, сильно не пинать, но конструктивную помощь приветствую. Имеется DataGridView, данные...

Недопустимое значение DataGridViewComboBoxCell
Здравствуйте, На форме есть DataGridView, привязанный к одной таблице mssql. таблица userForm: id- int первичный ключ ... ...

Исключение в DataGridView - недопустимое значение DataGridComboBoxCell
Создал несколько таблиц через &quot;Источники данных&quot; и для полей с внешними ключами настроил отображение в виде ComboBox. Первая таблица...

1
 Аватар для SkYMaaN
25 / 19 / 9
Регистрация: 05.04.2019
Сообщений: 338
20.02.2021, 04:12  [ТС]
Ошибка была по причине того, что устанавливаемое значение не было в Items
Готовое решение:
C#
1
2
dataGridView2.Rows[i].Cells[j] as DataGridViewComboBoxCell).Items.Add(dataTable.Rows[i][j]); //обязательно добавить значение в items, иначе ошибка
dataGridView2.Rows[i].Cells[j].Value = dataTable.Rows[i][j];
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.02.2021, 04:12
Помогаю со студенческими работами здесь

Недопустимое значение DataGridViewComboBoxCell
Есть таблица, которая из Data Sources вытаскивается на форму в виде DataGridView. В ней содержится поле, в котором содержится код записи из...

Ошибка при заполнении Combobox в dataGridView "Недопустимое значение"
Доброго времени суток! Прошу помочь со следующей проблемой: Вручную создал dataGridView. Связал с базой Access. Часть колонок - это...

Datagridview и DataGridViewComboBoxCell
Есть 2 класса: 1) class Project { string ProjectName int OwnerId string OwnerName }

Не открывается список DataGridViewComboBoxCell в DataGridView
Проблема в следующем. Мне необходимо импортировать данные с Excel. Но исходный файл *.xls строго не регламентированный. В файле...

Как удалить привязки DataGridViewComboBoxCell и DataGridViewCheckBoxCell из dataGridView ?
В сетку dataGridView1 вставлены ячейки с DataGridViewComboBoxCell и DataGridViewCheckBoxCell . Нужно сделать СБРОС dataGridView1 в...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru