Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/26: Рейтинг темы: голосов - 26, средняя оценка - 4.88
0 / 0 / 0
Регистрация: 07.03.2012
Сообщений: 4

Запись в Excel поcредством ADO

07.03.2012, 14:08. Показов 4788. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здраствуйте.

Подскажите пожалуйста как можно осуществить запись данных в Excel посредством ADO.
Уже больше недели рою интернет в поиске информации по этому вопросу. Гугление да и Яндекс не дали результатов. На других форумах тоже без результатно.

Использую С++ Builder 6.0 и стандартные компоненты палитры ADO.
Вот функция которая открывает файл. Здесь все работает без проблем.
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
   AnsiString mFile;
   if(OpDlg->Execute())
   {
     mFile = OpDlg->FileName;
     DM->ADOConnection1->Provider=WideString("Microsoft.Jet.OLEDB.4.0");
     DM->ADOConnection1->ConnectionString=WideString("Data Source="+mFile+";Extended Properties='Excel 8.0; 
 
HDR=No;IMEX=1'");
     DM->ADOConnection1->LoginPrompt=false;
     DM->ADOConnection1->GetTableNames(LBoxTableName->Items,NULL);
     static_cast<TCustomConnection*>(DM->ADOConnection1)->Open();
     DM->ADOQuery1->Connection=DM->ADOConnection1;
     DM->ADOQuery1->SQL->Text="select * from ["+ LBoxTableName->Items->Strings[0] +"]";
     DM->ADOQuery1->Open();
     int ColCnt = DBGrid1->Columns->Count;
     for(int i=0; i<ColCnt; i++)
     {
        TColumn * mCol = new TColumn(DBGrid1->Columns);
        mCol->FieldName = "F" + IntToStr(i+1);
        mCol->Width = 100;
     }
   }
   LabEdit_Number->SetFocus();
   if(!DM->ADOConnection1->Connected)
      ShowMessage("Ошибка  открытия файла");
[/code]
 
Эта функция производит поиск введенной в LabelEdit строки в файле Эксель.
Тоже все без проблем.
[code]
   if(DM->ADOConnection1->Connected)
   {
      if(LabEdit_Number->Text != "")
        DM->ADOQuery1->SQL->Text="select * from ["+ LBoxTableName->Items->Strings[0] +"] where 
 
F1='"+LabEdit_Number->Text+"'";
      else
        DM->ADOQuery1->SQL->Text="select * from ["+ LBoxTableName->Items->Strings[0] +"]";
      DM->ADOQuery1->Open();
      int ColCnt = DBGrid1->Columns->Count;
      for(int i=0; i<ColCnt; i++)
      {
          TColumn * mCol = new TColumn(DBGrid1->Columns);
          mCol->FieldName = "F" + IntToStr(i+1);
          mCol->Width = 100;
      }
   }
   else
   {
      ShowMessage("Необходимо открыть файл.");
      PMOpen1->Click();
   }
А вот здесь начинаються непонятки.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
   DM->ADOQuery1->Close();
   DM->ADOQuery1->SQL->Clear();    
//======= ВАРИАНТ №1 =========================
   DM->ADOQuery1->SQL->Add("update ["+ LBoxTableName->Items->Strings[0] +"] set F3=:F3 where F1=:F1");
   DM->ADOQuery1->Parameters->ParamByName("F1")->Value = LabEdit_Number->Text;
   DM->ADOQuery1->Parameters->ParamByName("F3")->Value = LabEdit_Count->Text;
//============================================
//======= ВАРИАНТ №2 =========================
   DM->ADOQuery1->SQL->Add("update ["+ LBoxTableName->Items->Strings[0] +"] set F3='"  + LabEdit_Count->Text +  "' where 
 
F1='"+ LabEdit_Number->Text+ "'");
//============================================
//======= ВАРИАНТ №3 =========================
//==== (от безисходности начал тупо экспериментировать)=======
   DM->ADOQuery1->SQL->Add("update ["+ LBoxTableName->Items->Strings[0] +"] set F3 values('" + LabEdit_Count->Text+ "') 
 
where F1='"+ LabEdit_Number->Text+ "'");
//============================================
   DM->ADOQuery1->ExecSQL();
содержимое DM->ADOQuery1->SQL->Text:
В ВАРИАНТе №1 - update [TDSheet$] set F3=:F3 where F1=:F1
В ВАРИАНТе №2 - update [TDSheet$] set F3='10' where F1='28113-2F000'
В ВАРИАНТе №3 - update [TDSheet$] set F3 values('10') where F1='28113-2F000'
Текст Ошибки:
В ВАРИАНТе №1 - ...raise exception class EOleException with message 'В операции должен использоваться обновляемый запрос'.

Process stopped.

В ВАРИАНТе №2 - ...raise exception class EOleException with message 'В операции должен использоваться обновляемый запрос'.

Process stopped.
В ВАРИАНТе №3 - Ошибка синтаксиса в инструкции UPDATE --- И не сомневался в этом

Не понятно, почему не работает Вариант №1. В другой программе при работе с Interbase все ОК - только вместо ADOQuery1 там используется IBDataSet и также все через параметры.

И также непонятно 'В операции должен использоваться обновляемый запрос' - пытался поискать в инете про это, но все написано как-то "в общем" - тоже не понял ничего.

Может кто-нибудь подскажет как эту проблему можно решить и что такое обновляемый запрос (впервые такое слышу)?

С Уважением, Дмитрий.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.03.2012, 14:08
Ответы с готовыми решениями:

Как пользуясь ADO извлечь строки c задаными критериями из одной книги Excel и поместить в другую книгу Excel?
Доброго времени суток, форумчане! Кто знает, подскажите пожалуйста, как с помощью ADO открыть соединение с другой книгой excel (с...

Запись в таблицу ADO
Привет всем. Столнкулся с непонятной фигней) Вобщем, заношу в запись новую информацию, и когда дело доходит до чисел, вылазит ошибка,...

ADO.NET и Excel
Может ли кто-нить помочь? Пытаюсь подключиться к файлу Excel через ADO. Вбиваю следующую строку подключения: Driver={Microsoft...

4
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
08.03.2012, 03:20
http://wladm.narod.ru/Borland/excel.html

Добавлено через 18 минут
Цитата Сообщение от bizisoft Посмотреть сообщение
DM->ADOQuery1->SQL->Add("update ["+ LBoxTableName->Items->Strings[0] +"]
А у тебя имя таблицы состоит из 2-х слов, что ты её берешь в квадратные скобки? или на русском языке?
0
0 / 0 / 0
Регистрация: 07.03.2012
Сообщений: 4
08.03.2012, 04:00  [ТС]
Цитата Сообщение от Sasha Посмотреть сообщение
Если я правильно понял, то ты предлагаешь сделать посредством OLE Automatisation.
А можно поинтересоваться по какой причине? И может ты подтвердишь ну или опровергнишь мои подозрения по поводу того, что подключение к Excel файлу посредством ADO осуществляется на правах "только для чтения" и ни о каких изменениях в файле речи быть не может. Что скажешь?

Спасибо за ссылку, но я с этим сайтом уже знаком - довадилось его читать, когда разбирался с OLE.

Я так уже и сам начинал склоняться, что прийдется делать по этой технологии, и начал уже переписывать проект под OLE, т.к. через ADO никак не получается произвести запись.

Жаль, а так хотелось обойтись без OLE, кто знает, может не окажеться на ПК установленного Office, хотя и здесь есть выход - OpenOffice OLE Automatisation.
Всякие возможности, которые предоставляет OLE типа форматирование текста, вставка формул мне никчему, мне просто необходимо осуществлять банальный поиск по одному столбцу и редактирование в соседнем (нашель искомое значение в ячейке A23 изменил значение в ячейке B23).

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

Спасибо, Sasha, что внес в мои мытарства ясность.
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
08.03.2012, 16:51
Я вообще сохраняю данные в CSV-формат, а потом открываю его екселем
0
0 / 0 / 0
Регистрация: 07.03.2012
Сообщений: 4
08.03.2012, 18:06  [ТС]
У меня, как-бы выбора нет.
Имеется Excel файл с номенклатурой, а моя программа является как бы прослойкой между этим файлом и терминалом сбора данных (ТСД).
ТСД считывает штрих-код и передает программе, которая в свою очередь производит поиск соответствия в файле и если находит, то оператор вводит количество и программа записывает это количество в ячейку рядом.
Потом с этим файлом будут работать другие люди.
А заниматься конвертированием файлов из одно формата в другой никто не будет.
Так, что только мне остается только *.xls.

С Уважением, Дмитрий.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.03.2012, 18:06
Помогаю со студенческими работами здесь

ADO + Excel = ошибка
Читаю данные из таблицы Excel через ADO: Dim cn As ADODB.Connection Set cn = New ADODB.Connection Dim rs As ADODB.Recordset Set...

Запись в базу access ADO
база access подключаюсь через ADO если несколько человек работают с программой то при изменении записи одним из них не происходит...

Считывание с txt и запись в ado
Добро всем! :senor: в тхт файле у меня порядка 1000 строк с шапкой, вот в таком виде: Сумма Ф.И.О. Адрес -кв ...

ADO.NET запись в Access
Здравствуйте. Есть база данных Access. Через c#.net подключаюсь к ней через. Выбрать данные получилось, а вот записать никак! Делал с...

ADO, Excel, типы полей
Добрый день! Подскажите, может кто сталкивался. Работаю с Excel из RAD_XE8 , через ADO, строка подключения:...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru