0 / 0 / 0
Регистрация: 10.05.2012
Сообщений: 34

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

23.05.2013, 18:19. Показов 2617. Ответов 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
3404 / 2175 / 353
Регистрация: 13.01.2012
Сообщений: 8,437
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
3404 / 2175 / 353
Регистрация: 13.01.2012
Сообщений: 8,437
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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
PowerShell Snippets
iNNOKENTIY21 11.11.2025
Модуль PowerShell 5. 1+ : Snippets. psm1 У меня модуль расположен в пользовательской папке модулей, по умолчанию: \Documents\WindowsPowerShell\Modules\Snippets\ А в самом низу файла-профиля. . .
PowerShell и онлайн сервисы. Валюта (floatrates.com руб.)
iNNOKENTIY21 11.11.2025
PowerShell функция floatrates-rub Примеры вызова: # Указанная валюта 'EUR' floatrates-rub -Code 'EUR' # Список имеющихся кодов валют floatrates-rub -Available function floatrates-rub {
PowerShell и онлайн сервисы. Погода (RP5.ru)
iNNOKENTIY21 11.11.2025
PowerShell функция Get-WeatherRP5rss для получения погоды с сервиса RP5 Примеры вызова Get-WeatherRP5rss с указанием id 5484 — Москва (восток, Измайлово) и переносом строки:. . .
PowerShell и онлайн сервисы. Погода (wttr)
iNNOKENTIY21 11.11.2025
PowerShell Функция для получения погоды с сервиса wttr Примеры вызова: Погода в городе Омск с прогнозом на день, можно изменить прогноз на более дней, для этого надо поменять запрос:. . .
PowerShell и онлайн сервисы. Валюта (ЦБР)
iNNOKENTIY21 11.11.2025
# Получение курса валют function cbr (] $Valutes = @('USD', 'EUR', 'CNY')) { $url = 'https:/ / www. cbr-xml-daily. ru/ daily_json. js' $data = Invoke-RestMethod -Uri $url $esc = 27 . . .
И решил я переделать этот ноут в машину для распределенных вычислений
Programma_Boinc 09.11.2025
И решил я переделать этот ноут в машину для распределенных вычислений Всем привет. А вот мой компьютер, переделанный из ноутбука. Был у меня ноут асус 2011 года. Со временем корпус превратился. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru