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

Не получается открыть dbf файл

23.05.2013, 18:19. Показов 2799. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
всем привет, хочу прочитать файл mytable, который находится c:\\mytable.dbf
пишу следующий код:

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
53
54
55
56
57
#include "stdafx.h"
#include <iostream>
#import "C:\Program Files\ADO\1182520763_msado15.dll" rename ("EOF", "ADOEOF") 
 
using namespace ADODB;
 
using std::cout;
using std::endl;
 
int _tmain(int argc, _TCHAR* argv[])
{
  HRESULT hr;
  CoInitialize(NULL);  
  
  _bstr_t strcnn("Driver={Microsoft dBASE Driver (*.dbf)};DriverID=277;Dbq=c:\;");
 
 
  try
  {
  _ConnectionPtr pConn("ADODB.Connection");
 
  hr = pConn->Open(strcnn, "", "", adConnectUnspecified);
  if (FAILED (hr))
  {
    cout << "connection is failed" << endl;
    system("PAUSE");
    return 1;
  }
 
  _RecordsetPtr pRec;
  pRec.CreateInstance("ADODB.Recordset");
  
  pRec->CursorLocation = adUseClient;
  pRec->CursorType = adOpenForwardOnly;
  pRec->PutRefActiveConnection(pConn);
 
  _bstr_t str ("Select * From mytable");
 
  pRec->Open("mytable",vtMissing,adOpenDynamic, adLockOptimistic, adCmdTable);
  //pRec = pConn->Execute(str, NULL, 0);
 
 
 // здесь идет дальше всякий код считывания данных, но до него выполнение не доходит, ошибка вылетает на строках выше
  system("PAUSE");
    return 0;
  }
  catch (_com_error& e) 
  {
    printf("Error ");
    printf(" Code = %08lx ", e.Error());
    printf(" Code meaning = %s ", e.ErrorMessage());
    printf(" Source = %s ", (LPCSTR) e.Source());
    printf(" Description = %s ", (LPCSTR) e.Description());
    system("PAUSE");
    return 1;
  }
}

ошибка происходит здесь в одной из функций, в зависимости от той которую использую
C++
1
2
pRec->Open("mytable",vtMissing,adOpenDynamic, adLockOptimistic, adCmdTable);
//pRec = pConn->Execute(str, NULL, 0);
ошибка звучит следующим образом: Error Code = 80040e37 Code meaning = I Source = Microsoft OLE DB Provider for
ODBC Drivers Description = [Microsoft][Драйвер ODBC dBase] Объект 'mytable' не
найден ядром базы данных Microsoft Jet. Проверьте существование объекта и прав
ильность имени и пути. Для продолжения нажмите любую клавишу . . .



перепробовал уже все, может у кого есть какие идеи, что я делаю неправильно?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
23.05.2013, 18:19
Ответы с готовыми решениями:

Как открыть и сохранить файл .dbf?
Через ODBC (Microsoft Visual FoxPro Driver)открыл файл .dbf (форма для заполнения реквизитов). Как теперь можно открыть уже существующий...

Открыть файл dbf с именем более 8 символов
Добрый день! Пытаюсь открыть файл dbf в 1С с именем более 8 символов, но через XBase не получается. Возможно ли как-то другими...

Как открыть dbf-файл в DAO для общего доступа?
Народ, помогите по сабжу...

5
Модератор
 Аватар для vxg
3409 / 2184 / 354
Регистрация: 13.01.2012
Сообщений: 8,462
23.05.2013, 22:39
может надо писать Dbq=c:\\mytable.dbf плюс указывать из какой таблицы брать (хотя она может быть у вас тоже называется mytable. короче не указана база. она должна быть либо определена в системе либо нужно ее указывать
1
0 / 0 / 0
Регистрация: 10.05.2012
Сообщений: 34
24.05.2013, 10:10  [ТС]
таблица, так же называется mytable, а в смысле указывать базу? я хочу же файлик один открыть? он у меня идет как одна таблица, в нем только одна вкладка и называется так же mytable. Путь все-таки нужно прописывать как я прописал, то есть только директорию без включения файла, иначе конекшн не будет установлен.
У меня конекшн устанавливается, а вот файл не читается
0
0 / 0 / 0
Регистрация: 24.05.2013
Сообщений: 12
24.05.2013, 10:27
Цитата Сообщение от monnzz Посмотреть сообщение
всем привет, хочу прочитать файл mytable, который находится c:\\mytable.dbf
пишу следующий код:

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
53
54
55
56
57
#include "stdafx.h"
#include <iostream>
#import "C:\Program Files\ADO\1182520763_msado15.dll" rename ("EOF", "ADOEOF") 
 
using namespace ADODB;
 
using std::cout;
using std::endl;
 
int _tmain(int argc, _TCHAR* argv[])
{
  HRESULT hr;
  CoInitialize(NULL);  
  
  _bstr_t strcnn("Driver={Microsoft dBASE Driver (*.dbf)};DriverID=277;Dbq=c:\;");
 
 
  try
  {
  _ConnectionPtr pConn("ADODB.Connection");
 
  hr = pConn->Open(strcnn, "", "", adConnectUnspecified);
  if (FAILED (hr))
  {
    cout << "connection is failed" << endl;
    system("PAUSE");
    return 1;
  }
 
  _RecordsetPtr pRec;
  pRec.CreateInstance("ADODB.Recordset");
  
  pRec->CursorLocation = adUseClient;
  pRec->CursorType = adOpenForwardOnly;
  pRec->PutRefActiveConnection(pConn);
 
  _bstr_t str ("Select * From mytable");
 
  pRec->Open("mytable",vtMissing,adOpenDynamic, adLockOptimistic, adCmdTable);
  //pRec = pConn->Execute(str, NULL, 0);
 
 
 // здесь идет дальше всякий код считывания данных, но до него выполнение не доходит, ошибка вылетает на строках выше
  system("PAUSE");
    return 0;
  }
  catch (_com_error& e) 
  {
    printf("Error ");
    printf(" Code = %08lx ", e.Error());
    printf(" Code meaning = %s ", e.ErrorMessage());
    printf(" Source = %s ", (LPCSTR) e.Source());
    printf(" Description = %s ", (LPCSTR) e.Description());
    system("PAUSE");
    return 1;
  }
}

ошибка происходит здесь в одной из функций, в зависимости от той которую использую
C++
1
2
pRec->Open("mytable",vtMissing,adOpenDynamic, adLockOptimistic, adCmdTable);
//pRec = pConn->Execute(str, NULL, 0);
ошибка звучит следующим образом: Error Code = 80040e37 Code meaning = I Source = Microsoft OLE DB Provider for
ODBC Drivers Description = [Microsoft][Драйвер ODBC dBase] Объект 'mytable' не
найден ядром базы данных Microsoft Jet. Проверьте существование объекта и прав
ильность имени и пути. Для продолжения нажмите любую клавишу . . .



перепробовал уже все, может у кого есть какие идеи, что я делаю неправильно?
А зачем здесь "c:\\mytable.dbf" два бэкслеша?

Добавлено через 5 минут
Цитата Сообщение от Mzx177 Посмотреть сообщение
А зачем здесь "c:\\mytable.dbf" два бэкслеша?
В программировании осталась еще возможность через прямой доступ читать файлы. Не редко приходилось решать так проблему. дбфки они простые по структуре - заголовок и данные. Читаешь заголовок (в нем названия полей, типы, размеры) и далее читаешь данные исходя из прочитанного заголовка. Аналогично пишешь в дбфку. Это кнч аварийный вариант, но если сроки поджимают, то почему бы и не поизголяться.
0
Модератор
 Аватар для vxg
3409 / 2184 / 354
Регистрация: 13.01.2012
Сообщений: 8,462
24.05.2013, 12:25
если файл открывается, то тогда остается то что нам советует система
Цитата Сообщение от monnzz Посмотреть сообщение
Проверьте существование объекта и прав
ильность имени и пути
1
0 / 0 / 0
Регистрация: 10.05.2012
Сообщений: 34
24.05.2013, 18:05  [ТС]
Друзья, всем спасибо, что откликнулись, но решил проблему следующим образом, сунул файл на диск D и директорию с С:\\, поменял на D:\\ и все заработало я хз, почему это так, но факт остается фактом

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

При попытке открыть DBF файл через OpenFileDialog вылетает ошибка
при попытке открыть DBF файл через OpenFileDialog вылетает ошибка private void открытьToolStripMenuItem_Click(object sender, EventArgs...

Как открыть DBF-файл, выбрать нужные данные и передать их в Текстбоксы ? HELP ME !!!
1. Открываем c: empwork.dbf 2. выбираем (SQL) SELECT A1, A2, A3, A4 FROM WORK WHERE A1=Text1.Text 3. передаём значения: Text2.Text...

Не получается открыть файл
Добрый день, необходимо реализовать обработку данных из файла, я написал следующий отрывок кода, но он всегда выдает false почему-то. ...

не получается открыть файл
всем привет. у меня такая проблема, когда я пишу в программе путь к файлу: char *file_name=&quot;C:\Users\Documents\Visual Studio...

Не получается открыть файл
На экран выводится, что не удалось открыть файл, а при компиляции, что переменная &quot;с&quot; не используется в фунции. Файл находится...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru