Форум программистов, компьютерный форум, киберфорум
Наши страницы
C#: Базы данных, ADO.NET
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
Alexosplain
0 / 0 / 0
Регистрация: 20.03.2012
Сообщений: 3
1

Exception: длина входного массива больше количества столбцов в таблице

20.03.2012, 14:40. Просмотров 563. Ответов 3
Метки нет (Все метки)

Проблема в том, что:
Через StreamReader я вытаскиваю данные из таблицы Excel и помещаю в DataSet, после чего отбражаю данные таблицы в DataGridView, но вот загвоздка, если в таблице Excel данных не много, то все выводится норм, а вот если записей больше 1000, то выводится Exception : Длина входного массива больше колличества столбцов в таблице. Помогите пожалуйста.

в классе DAL создаем метод
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
52
public DataSet GetCSVFileSite(string pathFileName)
{
try
{
if (File.Exists(pathFileName))
{
using (StreamReader siteReader = new StreamReader(pathFileName, Encoding.GetEncoding(1251) ))
{ 
string rowValue;
string[] cellValue;
SiteTD = new DataTable("SiteTable");
ExcelDataSet.Tables.Add(SiteTD);
 
rowValue = siteReader.ReadLine();
cellValue = rowValue.Split(';');
 
for (int i = 0; i <= cellValue.Count() - 1; i++)
{
 
dcHeader = new DataColumn();
ExcelDataSet.Tables["SiteTable"].Columns.Add(dcHeader);
dcHeader.Caption = cellValue;
dcHeader.ColumnName = cellValue;
 
} 
 
while ((rowValue = siteReader.ReadLine()) != null)
{
 
cellValue = rowValue.Split(';'); 
ExcelDataSet.Tables["SiteTable"].Rows.Add(cellValue);
 
}
 
siteReader.Close();
}
 
}
else
{
MessageBox.Show(@"Не существует файла базы c Сайта, подключите файл!!!", "НТС", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
 
}
 
catch (Exception e)
{
MessageBox.Show("Процесс соединения или вывода данных завершился неудачей!!!", e.ToString());
}
 
return ExcelDataSet;
}


Потом в классе самой формы наполняем Дата сет
C#
1
2
3
4
5
private void FillExcelDataSet(string pathSite, string pathElastix)
{
 
ExcelDataSet = dal.GetCSVFileSite(pathSite); 
}
и привязываем данные к DatagridView
C#
1
2
3
4
5
private void BindingDataGridView()
{ 
dgv_siteDB.DataSource = ExcelDataSet.Tables["SiteTable"];
 
}
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.03.2012, 14:40
Ответы с готовыми решениями:

Длина входного массива больше числа столбцов в этой таблице
Когда файл xml еще не создан программа добавляет строки по нажатию кнопки. Затем при втором запуске...

Длина входного массива больше числа столбцов в этой таблице
Имеем такой код и в указанной строке выдает &quot;проблему&quot; - длина входного массива больше числа...

Ошибка: Длина входного массива больше числа столбцов в этой таблице
подскажите в чём ошибка при запуске мне выдаёт &quot;Длина входного массива больше числа столбцов в этой...

Как устранить ошибку "Длина входного массива больше числа столбцов в этой таблице"?
Не пойму как устранить ошибку вроде столбцов 8 и массив с 8 элементов помогите найти ошибку...

Зарос на получение количества столбцов в таблице
Всем доброго времени. Нужно получить число столбцов в таблице MS sql server. такой код SELECT...

3
serg42
121 / 103 / 7
Регистрация: 14.02.2010
Сообщений: 263
20.03.2012, 14:56 2
Цитата Сообщение от Alexosplain Посмотреть сообщение
Длина входного массива больше колличества столбцов в таблице.
Проверяйте количество объектов в входном массиве перед добавлением в таблицу.
1
Alexosplain
0 / 0 / 0
Регистрация: 20.03.2012
Сообщений: 3
21.03.2012, 10:27  [ТС] 3
Спасибо тебе огромное за помощь. Ты меня наставил на правильное решение. очень признателен тебе.
0
serg42
121 / 103 / 7
Регистрация: 14.02.2010
Сообщений: 263
21.03.2012, 10:37 4
Цитата Сообщение от Alexosplain Посмотреть сообщение
Спасибо тебе огромное за помощь. Ты меня наставил на правильное решение. очень признателен тебе.
Да не за что. Всегда рад исполнять обязанности капитана очевидность.
0
21.03.2012, 10:37
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
21.03.2012, 10:37

Поиск количества столбцов матрицы, содержащих больше трех положительных элементов
Помогите пожалуйста с написанием кода. Дан двумерный массив, размерность массива и элементы...

Удалить из массива все серии, длина которых больше k
2. Дано число k и целочисленный массив размера N . Удалить из массива все серии, длина которых...

Удалить из массива все серии, длина которых больше k
Задача: Дан массив, состоящий из n элементов. Назовем серией группу подряд идущих одинаковых...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

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