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

Чтение xls файла

10.07.2013, 11:20. Показов 8718. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем добрый день!

Очень нуждаюсь в вашей помощи.
У меня есть большое количество xls файлов, отличаются они наименованием и содержанием.
Чтение файла сделала, но открывается всегда только один файл.

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
 Microsoft.Office.Interop.Excel.Application ExcelApp = new Microsoft.Office.Interop.Excel.Application();
           ExcelApp.Visible = true;
           Excel.Workbook xlWorkBook;
           Excel.Worksheet xlWorkSheet;
 
           object misValue = System.Reflection.Missing.Value;
                               
           
           xlWorkBook = ExcelApp.Workbooks.Open("W:\\OWS_TRANSFER\\Posss\\Тех.Карты\\9999xxxx\\9999*.xls", Type.Missing, Type.Missing, Type.Missing, Type.Missing,
      Type.Missing, Type.Missing, Type.Missing, Type.Missing,
      Type.Missing, Type.Missing, Type.Missing, Type.Missing,
      Type.Missing, Type.Missing);
 
           string fullfilesPath = Directory.GetFiles(ECOM_Form.direct_import(), file + ".xls").ToString();
           fmParent.textBox49.Text = file;          
 
 
           xlWorkSheet = (Microsoft.Office.Interop.Excel.Worksheet)xlWorkBook.Worksheets.get_Item(1);
Понимаю, что не правильно указываю путь, но не понимаю в чем. как сделать общий путь, чтоб можно было открывать любой файл с этой паки?

Заранее блогадарю.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
10.07.2013, 11:20
Ответы с готовыми решениями:

Чтение из XLS и обработка
Всем привет! Извиняюсь за свою наглость за возможно столь тупой вопрос, но адекватного ответа нигде не смог найти. Дано: файл xls....

Как организовать совместное чтение .xlsx и .xls?
Как организовать совместное чтение .xlsx и .xls using System; using System.Collections; using System.Collections.Generic; using...

Редактирование xls файла
Доброго времени суток, форумчане! Задача состоит в том чтобы отредактировать Exel файл, вот код: using System; using...

15
Эксперт Java
 Аватар для turbanoff
4094 / 3828 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 12
10.07.2013, 11:46
Цитата Сообщение от Алинка27 Посмотреть сообщение
как сделать общий путь, чтоб можно было открывать любой файл с этой паки?
Перебрать самому файлы в папке, и открывать тот который нужно.
0
0 / 0 / 0
Регистрация: 24.05.2011
Сообщений: 43
10.07.2013, 12:21  [ТС]
Цитата Сообщение от turbanoff Посмотреть сообщение
Перебрать самому файлы в папке, и открывать тот который нужно.
Доступ должен быть ко всем документам с этой папки.
0
 Аватар для Kruds
708 / 708 / 226
Регистрация: 04.03.2013
Сообщений: 1,384
10.07.2013, 12:36
Используйте диалоговое окно
C#
1
2
3
4
5
6
7
8
OpenFileDialog dial= new OpenFileDialog();
dial.InitialDirectory = "W:\\OWS_TRANSFER\\Posss\\Тех.Карты\\9999xxxx\\" ;
dial.Filter = "Excel files (*.xls, *.xlsx, *.xlsm)|*.xls;*.xlsx;*.xlsm" ;
if(dial.ShowDialog() == DialogResult.OK)
     xlWorkBook = ExcelApp.Workbooks.Open(dial.FileName, Type.Missing, Type.Missing, Type.Missing, Type.Missing, 
      Type.Missing, Type.Missing, Type.Missing, Type.Missing,
      Type.Missing, Type.Missing, Type.Missing, Type.Missing,
      Type.Missing, Type.Missing);
0
Эксперт Java
 Аватар для turbanoff
4094 / 3828 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 12
10.07.2013, 12:44
Цитата Сообщение от Алинка27 Посмотреть сообщение
Доступ должен быть ко всем документам с этой папки.
Вы хотите открыть все файлы разом, или что? Какое это имеет отношение, к тому что я написал?
0
0 / 0 / 0
Регистрация: 24.05.2011
Сообщений: 43
10.07.2013, 12:51  [ТС]
Цитата Сообщение от Kruds Посмотреть сообщение
Используйте диалоговое окно
C#
1
2
3
4
5
6
7
8
OpenFileDialog dial= new OpenFileDialog();
dial.InitialDirectory = "W:\\OWS_TRANSFER\\Posss\\Тех.Карты\\9999xxxx\\" ;
dial.Filter = "Excel files (*.xls, *.xlsx, *.xlsm)|*.xls;*.xlsx;*.xlsm" ;
if(dial.ShowDialog() == DialogResult.OK)
     xlWorkBook = ExcelApp.Workbooks.Open(dial.FileName, Type.Missing, Type.Missing, Type.Missing, Type.Missing, 
      Type.Missing, Type.Missing, Type.Missing, Type.Missing,
      Type.Missing, Type.Missing, Type.Missing, Type.Missing,
      Type.Missing, Type.Missing);

Диологовое окно не подойдет, данные файлы я отобразила на treeview ввиде списка и при нажатии на каждого, они должны открываться и все их данные должны записываться по textbox-ам.

Добавлено через 3 минуты
Цитата Сообщение от turbanoff Посмотреть сообщение
Вы хотите открыть все файлы разом, или что? Какое это имеет отношение, к тому что я написал?
Как и писала выше, данные документы отображаются в treeView, и при нажатии на любого , их данные должны записываться по textBox-ам.
0
 Аватар для Kruds
708 / 708 / 226
Регистрация: 04.03.2013
Сообщений: 1,384
10.07.2013, 12:52
C#
1
2
3
4
5
6
7
8
9
//пусть лист в списке "filename.xls"
void treeView1_NodeMouseClick(object sender,  TreeNodeMouseClickEventArgs e)
{
   string directory = "W:\\OWS_TRANSFER\\Posss\\Тех.Карты\\9999xxxx\\";
   xlWorkBook = ExcelApp.Workbooks.Open(directory + e.Node.Text, Type.Missing, Type.Missing, Type.Missing, Type.Missing, 
      Type.Missing, Type.Missing, Type.Missing, Type.Missing,
      Type.Missing, Type.Missing, Type.Missing, Type.Missing,
      Type.Missing, Type.Missing);
}
0
Эксперт Java
 Аватар для turbanoff
4094 / 3828 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 12
10.07.2013, 12:59
Цитата Сообщение от Алинка27 Посмотреть сообщение
данные документы отображаются в treeView
Значит вам надо брать имя файла из treeview и открывать его.
0
0 / 0 / 0
Регистрация: 24.05.2011
Сообщений: 43
10.07.2013, 13:08  [ТС]
Цитата Сообщение от Kruds Посмотреть сообщение
C#
1
2
3
4
5
6
7
8
9
//пусть лист в списке "filename.xls"
void treeView1_NodeMouseClick(object sender,  TreeNodeMouseClickEventArgs e)
{
   string directory = "W:\\OWS_TRANSFER\\Posss\\Тех.Карты\\9999xxxx\\";
   xlWorkBook = ExcelApp.Workbooks.Open(directory + e.Node.Text, Type.Missing, Type.Missing, Type.Missing, Type.Missing, 
      Type.Missing, Type.Missing, Type.Missing, Type.Missing,
      Type.Missing, Type.Missing, Type.Missing, Type.Missing,
      Type.Missing, Type.Missing);
}
не работает, не может найти данный файл.
0
 Аватар для Kruds
708 / 708 / 226
Регистрация: 04.03.2013
Сообщений: 1,384
10.07.2013, 13:12
Цитата Сообщение от Алинка27 Посмотреть сообщение
не работает, не может найти данный файл.
Доработайте обработчик с поправкой на то, где у вас имена файлов и в каком виде.
0
Эксперт Java
 Аватар для turbanoff
4094 / 3828 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 12
10.07.2013, 13:14
Цитата Сообщение от Алинка27 Посмотреть сообщение
directory + e.Node.Text
Посмотрите значение этого выражения в отладчике. И проверьте правильность пути.
0
0 / 0 / 0
Регистрация: 24.05.2011
Сообщений: 43
10.07.2013, 13:22  [ТС]
Цитата Сообщение от Kruds Посмотреть сообщение
Доработайте обработчик с поправкой на то, где у вас имена файлов и в каком виде.
Код работает и записывает по всем полям, только он всегда открывает только первый файл, как то путь там должен быть другим. Не понимаю как сделать, чтоб он открыл выбранный документ.
0
 Аватар для Kruds
708 / 708 / 226
Регистрация: 04.03.2013
Сообщений: 1,384
10.07.2013, 13:32
Воспользуйтесь отладчиком как подсказали выше. Посмотрите какой текст в кликаемом узле, как он передается в метод Open, станет ясно почему открывается не тот документ.
1
0 / 0 / 0
Регистрация: 24.05.2011
Сообщений: 43
10.07.2013, 14:00  [ТС]
Цитата Сообщение от Kruds Посмотреть сообщение
Воспользуйтесь отладчиком как подсказали выше. Посмотрите какой текст в кликаемом узле, как он передается в метод Open, станет ясно почему открывается не тот документ.
Да все правильно вроде:

directory = "W:\\OWS_TRANSFER\\Posss\\Тех.Карты\\999 9xxxx\\"
Node = {Text = "99990029"}

Добавлено через 10 минут
Цитата Сообщение от Kruds Посмотреть сообщение
Воспользуйтесь отладчиком как подсказали выше. Посмотрите какой текст в кликаемом узле, как он передается в метод Open, станет ясно почему открывается не тот документ.
Все заработало, Ваш код правильный, только там надо было дописать ".xls"


C#
1
2
3
4
5
string directory = "W:\\OWS_TRANSFER\\Posss\\Тех.Карты\\9999xxxx\\";
            xlWorkBook = ExcelApp.Workbooks.Open(directory + e.Node.Text + ".xls", Type.Missing, Type.Missing, Type.Missing, Type.Missing,
               Type.Missing, Type.Missing, Type.Missing, Type.Missing,
               Type.Missing, Type.Missing, Type.Missing, Type.Missing,
               Type.Missing, Type.Missing);
Спасибо за помощь!
0
 Аватар для Kruds
708 / 708 / 226
Регистрация: 04.03.2013
Сообщений: 1,384
10.07.2013, 14:02
99990029 - имя файла? В таком случае в Open надо передавать строку directory + e.Node.Text + ".xls"
Но это не лучший выход. Если файл с поддержкой макросов или из 7+ офиса, то опять же не откроется. Лучше настройте запись имен файлов в дерево вместе с расширением.
1
0 / 0 / 0
Регистрация: 24.05.2011
Сообщений: 43
10.07.2013, 14:08  [ТС]
Цитата Сообщение от Kruds Посмотреть сообщение
99990029 - имя файла? В таком случае в Open надо передавать строку directory + e.Node.Text + ".xls"
Но это не лучший выход. Если файл с поддержкой макросов или из 7+ офиса, то опять же не откроется. Лучше настройте запись имен файлов в дерево вместе с расширением.
Да-да, разобралась.

еще раз спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.07.2013, 14:08
Помогаю со студенческими работами здесь

Ошибка чтения xls-файла
Хелп плиз! При попытке использования xls-файла выскакивает сообщение об ошибке Interop type...

Изменение Xml-файла внутри XLS
Если открыть через архиватор XLS файл то можно обнаружить что там есть разные xml-ки. Как из c# редактировать их

Как программно узнать сколько листов у файла xls
Здравствуйте! Подскажите пожалуйста, как это сделать.

Исключение HRESULT: 0x800A03EC при открытии xls файла
Есть функция, которая открывает файл эксель считывает из него названия листов и возвращает его в списке. List<string>...

Чтение списка из файла и дальнейшее использование информации из файла
основная using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; ...


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

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru