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

Запросом считать ячейки Excel файла

04.04.2015, 11:39. Показов 2695. Ответов 13
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
немогу запросом считать ячейки эксель файла.
перешарил и перегуглил много всего - безуспешно.

либо включю ссылку ругается на интероп либо на олеконн. либо еще что..

может кто привести пример.
есть файл тест.хлсх

как считать оттуда ячейку лист2 А1 и лист 4 С3 ?

Добавлено через 8 часов 58 минут
вопрос актуален
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.04.2015, 11:39
Ответы с готовыми решениями:

Считать данные c ячейки Excel
Помогите осуществить считывание конкретной ячейки с excel файла, при нажатии на кнопку чтобы в Edit появились данные(значения) ячейки.

Считать значение с ячейки Excel
Хелп котаны. Почему ничего не присваивает?)) Главное в ячейку можно записать, а считать нет. Что делать?) S:=Excel.Range;

Считать значение из ячейки таблицы Excel
Как например в int x записать значение из ячейки таблицы эксель файла... ? { //Создаём приложение. ...

13
 Аватар для СвободныйНик
191 / 180 / 114
Регистрация: 28.07.2013
Сообщений: 610
04.04.2015, 14:53
вот небольшой пример:
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
using Excel = Microsoft.Office.Interop.Excel;
...
private Excel.Application excelapp;
private Excel.Range excelcells;
private Excel.Sheets excelsheets;
private Excel.Worksheet excelworksheet;
private Excel.Workbook excelappworkbook;
...
string value_A1, value_C3;
...
excelapp = new Excel.Application(); 
excelapp.Visible = false;
excelappworkbook=excelapp.Workbooks.Open(@"C:\Excel_файл.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);
excelsheets = excelappworkbook.Worksheets;
excelworksheet=(Excel.Worksheet)excelsheets.get_Item("лист2");
excelcells = excelworksheet.get_Range("A1");
value_A1 = excelcells.Text.ToString();
excelworksheet=(Excel.Worksheet)excelsheets.get_Item("лист 4");
value_C3 = excelworksheet.get_Range("C3");
excelapp.Application.Quit();
 
object oExcel = Marshal.GetActiveObject("Excel.Application");
Marshal.ReleaseComObject(oExcel);
GC.GetTotalMemory(true);
1
3 / 3 / 0
Регистрация: 26.11.2013
Сообщений: 129
05.04.2015, 02:30  [ТС]
меня интересует именно адо.нет... этот способ я хорошо знаю


но надо именно
C#
1
using System.Data.OleDb;
0
 Аватар для СвободныйНик
191 / 180 / 114
Регистрация: 28.07.2013
Сообщений: 610
05.04.2015, 14:54
Цитата Сообщение от andryshka69 Посмотреть сообщение
но надо именно
C#
1
using System.Data.OleDb;
тогда так:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
string value_A1, value_C3;
...
string filename = @"C:\Excel_файл.xls";
string strConn = String.Format("Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=\"Excel 8.0;HDR=No;IMEX=1\";Data Source={0}", filename);           
OleDbConnection oConn = new OleDbConnection();
oConn.ConnectionString = strConn;
oConn.Open();
OleDbDataAdapter oCmd1 = new OleDbDataAdapter("SELECT * FROM [лист2$]", oConn);
OleDbDataAdapter oCmd2 = new OleDbDataAdapter("SELECT * FROM [лист 4$]", oConn);
 
DataSet oDS = new DataSet();
oDS.Tables.Add(new DataTable("лист2"));
oDS.Tables.Add(new DataTable("лист 4"));
oCmd1.Fill(oDS.Tables["лист2"]);
oCmd2.Fill(oDS.Tables["лист 4"]);
 
value_A1 = oDS.Tables["лист2"].Rows[0][0].ToString();
value_C3 = oDS.Tables["лист 4"].Rows[2][2].ToString();
oConn.Close();
1
3 / 3 / 0
Регистрация: 26.11.2013
Сообщений: 129
05.04.2015, 16:54  [ТС]
СвободныйНик

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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.OleDb;
 
namespace ClassLibrary1
{
    public class Class1
    {
        string value_A1, value_C3;
 
        string filename = @"C:\SFv3.xlsx";
string strConn = String.Format("Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=\"Excel 12.0;HDR=No;IMEX=1\";Data Source={0}", filename);           
OleDbConnection oConn = new OleDbConnection();
oConn.ConnectionString = strConn;
oConn.Open();
OleDbDataAdapter oCmd1 = new OleDbDataAdapter("SELECT * FROM [лист2$]", oConn);
OleDbDataAdapter oCmd2 = new OleDbDataAdapter("SELECT * FROM [лист 4$]", oConn);
 
DataSet oDS = new DataSet();
oDS.Tables.Add(new DataTable("лист2"));
oDS.Tables.Add(new DataTable("лист 4"));
oCmd1.Fill(oDS.Tables["лист2"]);
oCmd2.Fill(oDS.Tables["лист 4"]);
 
value_A1 = oDS.Tables["лист2"].Rows[0][0].ToString();
value_C3 = oDS.Tables["лист 4"].Rows[2][2].ToString();
oConn.Close();
    }
}

ругается на все подряд, говорит "является поле, используется как тип"...
0
 Аватар для СвободныйНик
191 / 180 / 114
Регистрация: 28.07.2013
Сообщений: 610
05.04.2015, 17:24
C#
1
using System.Data;
1
3 / 3 / 0
Регистрация: 26.11.2013
Сообщений: 129
05.04.2015, 17:27  [ТС]
СвободныйНик

не помогло
0
 Аватар для СвободныйНик
191 / 180 / 114
Регистрация: 28.07.2013
Сообщений: 610
05.04.2015, 17:44
Цитата Сообщение от andryshka69 Посмотреть сообщение
не помогло
где-то в другом ошибка.
скинь на что именно ругается или проект, у меня всё работает.

Добавлено через 9 минут
Офис 2007 или выше?
C#
1
string strConn = String.Format("Provider=Microsoft.ACE.OLEDB.12.0;Extended Properties=\"Excel 12.0;HDR=No;IMEX=1\";Data Source={0}", filename);
0
3 / 3 / 0
Регистрация: 26.11.2013
Сообщений: 129
05.04.2015, 17:52  [ТС]
СвободныйНик

проект
http://my-files.ru/cc5us5
0
 Аватар для СвободныйНик
191 / 180 / 114
Регистрация: 28.07.2013
Сообщений: 610
05.04.2015, 18:10
Лучший ответ Сообщение было отмечено andryshka69 как решение

Решение

ругается при компиляции?
Кликните здесь для просмотра всего текста
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
using System;
using System.Data;
using System.Collections.Generic;
using System.ComponentModel;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.OleDb;
 
namespace WindowsFormsApplication2
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
        string value_A1, value_C3;
        
        void Button1Click(object sender, EventArgs e)
        {
            string filename = @"C:\SFv3.xlsx";
            string strConn = String.Format("Provider=Microsoft.ACE.OLEDB.12.0;Extended Properties=\"Excel 12.0;HDR=No;IMEX=1\";Data Source={0}", filename);           
            OleDbConnection oConn = new OleDbConnection();
            oConn.ConnectionString = strConn;
            oConn.Open();
            OleDbDataAdapter oCmd1 = new OleDbDataAdapter("SELECT * FROM [лист2$]", oConn);
            OleDbDataAdapter oCmd2 = new OleDbDataAdapter("SELECT * FROM [лист 4$]", oConn);
 
            DataSet oDS = new DataSet();
            oDS.Tables.Add(new DataTable("лист2"));
            oDS.Tables.Add(new DataTable("лист 4"));
            oCmd1.Fill(oDS.Tables["лист2"]);
            oCmd2.Fill(oDS.Tables["лист 4"]);
    
            value_A1 = oDS.Tables["лист2"].Rows[0][0].ToString();
            value_C3 = oDS.Tables["лист 4"].Rows[2][2].ToString();
            oConn.Close();
        }
    }
}
0
3 / 3 / 0
Регистрация: 26.11.2013
Сообщений: 129
05.04.2015, 18:35  [ТС]
СвободныйНик
ВСЕ РАБОТАЕТ.

ты лучший.
0
 Аватар для СвободныйНик
191 / 180 / 114
Регистрация: 28.07.2013
Сообщений: 610
05.04.2015, 18:39
Цитата Сообщение от andryshka69 Посмотреть сообщение
Недопустимое имя 'лист1$'
а как лист называется?
в коде лист 1, а в ошибке лист1
0
3 / 3 / 0
Регистрация: 26.11.2013
Сообщений: 129
05.04.2015, 18:41  [ТС]
СвободныйНик


как шарп реагирует на параллельное использование программ,
например копий будет открыто одновременно порядка 20
могут ли они одновременно конектиться к 1 файлу экселя (только для чтения) без проблем?
0
 Аватар для СвободныйНик
191 / 180 / 114
Регистрация: 28.07.2013
Сообщений: 610
05.04.2015, 18:52
Цитата Сообщение от andryshka69 Посмотреть сообщение
могут ли они одновременно конектиться к 1 файлу экселя (только для чтения)
проблем с этим не наблюдал
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.04.2015, 18:52
Помогаю со студенческими работами здесь

Считать данные из ячейки excel, и записать её в combobox
Как считать данные из ячейки excel. Что бы после это её можно было выбрать в combobox? Пробовал найти, в нигде ничего толкового нет.

Считать данные из ячейки excel, и записать её в combobox
Добрый вечер! Не могли бы вы помочь с записью в combobox, ич ячейки Excel. Желательно с объяснением. Был бы очень признателен.

Открытие файла Excel, полученного POST запросом
Здравствуйте! Помогите пожалуйста с кодом в VB Excel 2013: получаю файл Excel посредством POST запроса в переменную somefile. Файл в...

Считать данные с Excel файла
Не могу понять почему ругается компилятор(( и кто может ответить почему в Add Reference во вкладке .NET отсутствуют первичные сборки...

Как считать из файла Excel по ячейкам?
Нужно соединится с файлом Excel и считывать из него информацию по ячеечно. Кусочек кода бы или где почитать.


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

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор значений справочника
Maks 21.03.2026
Установка программного отбора значений справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru