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

Работа с таблицей Excel

28.12.2021, 18:48. Показов 923. Ответов 7

Студворк — интернет-сервис помощи студентам
Добрый вечер! Подскажите пожалуйста. У меня есть готовая таблица excel. Моя задача добавить на форму кнопку, при нажатии на которую в datagridview запускался КОНКРЕТНЫЙ excel файл. Каким образом я могу это осуществить? Видел варианты с выбором файла из проводника, который нужно открыть, но это все не то. В разработке на C# опыта практически нет, но это не отменяет мою задачу).
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
28.12.2021, 18:48
Ответы с готовыми решениями:

Работа со сложной xls таблицей
Здравствуйте. Подскажите как решить такую проблему. Есть телефонный справочник в xls формате. Таблица сложная, разное количество клеток в...

Работа с таблицей
Доброго времени суток! Работаю с таблицей DataGridView. Как прочитать данные из той или иной ячейки? Заранее большое спасибо!

Работа с иерархической таблицей
Может кто подскажет стандартные приемы организации работы с иерархической таблицей. Я пока работаю с визуальным редактором. В связи с этим...

7
 Аватар для ViterAlex
8951 / 4863 / 1886
Регистрация: 11.02.2013
Сообщений: 10,246
29.12.2021, 02:54
Что значит "запускался"? Данные из файла нужно перенести в dgv? Или открыть внутри приложения экземпляр Excel и внутри него открыть файл? Сколько листов в книге? Нужно ли отображать диаграммы и сводные таблицы?
Подразумевается, что Excel установлен или нужно не привязываться к его наличию?
0
74 / 48 / 27
Регистрация: 25.03.2014
Сообщений: 357
Записей в блоге: 1
29.12.2021, 06:08
Karuselkin,
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
 string filename = Path.GetFullPath("bok123.xlsx");
            string str;
            int rCnt;
            int cCnt;
            Microsoft.Office.Interop.Excel.Application ExcelApp = new Microsoft.Office.Interop.Excel.Application();
            Microsoft.Office.Interop.Excel._Workbook ExcelWorkBook;
            Microsoft.Office.Interop.Excel.Worksheet ExcelWorkSheet;
            Microsoft.Office.Interop.Excel.Range ExcelRange;
 
            ExcelWorkBook = ExcelApp.Workbooks.Open(filename, 0, true, 5, "", "", true, Microsoft.Office.Interop.Excel.XlPlatform.xlWindows, "\t", false,
                false, 0, true, 1, 0);
 
            int sheetcount = ExcelWorkBook.Sheets.Count;
            for (int i = 0; i < sheetcount && i < tabControl1.Controls.Count; i++)
            {
                ExcelWorkSheet = (Microsoft.Office.Interop.Excel.Worksheet)ExcelWorkBook.Worksheets.get_Item(i + 1);
                //tabControl1.SelectedIndex = i;
                  ExcelRange = ExcelWorkSheet.UsedRange;
                int colCount = ExcelRange.Columns.Count; //размер колонок
                int rowCount = ExcelRange.Rows.Count;// размер строк
                for (rCnt = 1; rCnt <= rowCount; rCnt++)
                {
 
                    ((DataGridView)this.tabControl1.TabPages[i].Controls[0]).Rows.Add(1);
                    for (cCnt = 1; cCnt <= colCount; cCnt++)
                    {
                        ((DataGridView)this.tabControl1.TabPages[i].Controls[0]).Rows[rCnt - 1].Cells[cCnt - 1].Value = (ExcelRange.Cells[rCnt, cCnt] as Microsoft.Office.Interop.Excel.Range).Value;
                    }
                }
            }
            ExcelWorkBook.Close(true, null, null);
            ExcelApp.Quit();
 
 
 
            GC.WaitForPendingFinalizers();
            GC.Collect();
            GC.WaitForPendingFinalizers();
            GC.Collect();

Сразу оговорюсь что код выводит каждый лист в свой datagridview, я выкладывал где то на форуме этот код для кого то
1
 Аватар для ViterAlex
8951 / 4863 / 1886
Регистрация: 11.02.2013
Сообщений: 10,246
29.12.2021, 12:47
студент1235, неплохо. Но UsedRange очень коварная штука. Если к ячейка пустая, но к ней применено форматирование, отличное от других, то она будет влиять на UsedRange
0
0 / 0 / 0
Регистрация: 13.12.2021
Сообщений: 5
29.12.2021, 15:07  [ТС]
А path и tabcontrol1 это какие в этом случае элементы? А то он их красным подсвечивает, пишет нет в контексте
0
0 / 0 / 0
Регистрация: 13.12.2021
Сообщений: 5
29.12.2021, 15:14  [ТС]
В файле 1 лист содержащий шапку таблицы, больше там ничего нет. Под слово открыть я подразумевал отображение таблицы вместе с этой шапкой в datagridview.

Вообще, суть задачи в том, чтобы у меня на второй форме появилась таблица, которая будет автоматически заполняться после расчетов.
НО. Шапка таблицы у меня выглядит следующим образом. Поэтому единственный вариант, который я придумал это импортировать готовый файл excel в datagridview. Возможно, есть вариант куда-более легче.
Миниатюры
Работа с таблицей Excel  
0
0 / 0 / 0
Регистрация: 13.12.2021
Сообщений: 5
29.12.2021, 19:02  [ТС]
Выдает такую ошибку:
Исключение не обработано
System.ArgumentOutOfRangeException: "Индекс 0 вне допустимого диапазона.
Имя параметра: index"
C#
1
((DataGridView)this.tabControl1.TabPages[i].Controls[0]).Rows.Add(1);
Это 24 строка вашего кода

Добавлено через 41 минуту
Всем спасибо за помощь, вариант с тем кодом рабочий, но не под мой случай. Проверил на обычной таблице без объединения ячеек и прочего - выводит все как надо
0
74 / 48 / 27
Регистрация: 25.03.2014
Сообщений: 357
Записей в блоге: 1
10.01.2022, 05:52
Не по теме: ViterAlex, Сорри что так поздно, аккаунт только в одном месте был, в моем проекте не важно пустая будет или нет. Но совет учту.
У меня в проекте цель была выгрузить все что видит пользователь на экране в удобном виде и по листам так чтобы данные от разных источников не смешивались в файле и были удобно читаемые т.к. дальше с полученной информацией да и в целом с программой будут пользоваться специалисты другого направления.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.01.2022, 05:52
Помогаю со студенческими работами здесь

Word работа с таблицей
В документе имеется таблица: Word.Table oldTable = document.Tables; Как получить ширину и высоту каждой ячейки и по ним создать в...

Работа с таблицей XAML
Здравствуйте. Приведите, пожалуйста, пример реализации следующего: в основном окне есть таблица 2х2. Верхняя строка красного цвета, нижняя...

Работа с внешней таблицей
Есть огромная таблица 100х7. И её значения нужно использовать в проге, БЕЗ datagrid!!! Саму таблицу в проге не должно быть видно!!! Она...

Работа с таблицей Word
Учусь работать с Word с помощью C#. В программеnamespace CsWordCons { class Program { static void Main(string args) {...

Возможно ли сделать так, чтобы таблица в Excel была связана с таблицей в Аксесе?
А может и нет. Скажите, подалуйста, а возможно ли сделать так, чтобы таблица в Excel была связана с таблицей в Аксесе. Первая таблица...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 25.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 и т. д. Сборка примера Скачайте. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru