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

Считать дату в таблицу из dbf файла

11.12.2020, 09:46. Показов 2491. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!
Считываю из dbf файла строки в базу данных с помощью компонента TDbf и ADO.
Всё отрабатывает, но так как функция getfielddata строковая, то даты считываются некорректно. 22.03.1969 становится 22.03.2069. Как считать дату в виде даты?

Вот часть кода:

Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
   DBF1.Open;
   DBF1.CodePage:=OEM;
   DBF1.First;
     for i:=0 to DBF1.RecordCount-1 do
 begin
         Table2.Active:=True;
          Table2.Insert;
     Table2.FieldByName('surname').AsString:=dBF1.GetFieldData(2);
   Table2.FieldByName('name').AsString:=dBF1.GetFieldData(3);
   Table2.FieldByName('patron').AsString:=dBF1.GetFieldData(4);
   Table2.FieldByName('bdate').AsDateTime:=StrToDate(dBF1.GetFieldData(5));
   Table2.FieldByName('pol').AsString:=dBF1.GetFieldData(6);
   Table2.FieldByName('address').AsString:=dBF1.GetFieldData(7);
    Table2.Post;
   Table2.Active:=false;
     DBF1.Next;
     end;
    DBF1.Post;
    DBF1.Close;
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.12.2020, 09:46
Ответы с готовыми решениями:

Импорт csv-файла в dbf-таблицу
using System; using System.Collections.Generic; using System.Linq; using System.Text; using SocialExplorer.IO.FastDBF; using...

Проблема с сохранением тексового файла в таблицу dbf
Всем привет! Есть проблема! Мне необходимо с текстового файла (формат dos) перегнать данные в таблицу формата дбф. подключаюсь через...

Как считать дату из EXIF jpeg файла?
Как считать дату из EXIF jpeg файла?

10
 Аватар для krapotkin
6849 / 4676 / 1464
Регистрация: 14.04.2014
Сообщений: 20,671
Записей в блоге: 21
11.12.2020, 17:35
просто вычесть 1000 лет не предлагать?

сильно предполагаю, что в файле просто 22.03.69 записано
поэтому система сама решает, какой год имелся в виду
она и выбрала ближайший
0
Модератор
 Аватар для D1973
9924 / 6460 / 2457
Регистрация: 21.01.2014
Сообщений: 27,410
Записей в блоге: 3
11.12.2020, 18:12
Цитата Сообщение от krapotkin Посмотреть сообщение
просто вычесть 1000 лет не предлагать?
Не надо так много, 100 достаточно
0
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,507
12.12.2020, 00:47
Выложите свой dbf файл. Интересно посмотреть.
0
 Аватар для Пытливый
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
12.12.2020, 21:24
Скорее всего файл версии DBase III, можно сохранить в DBase V и тогда вроде как в дате тысячелетия появятся.
0
 Аватар для krapotkin
6849 / 4676 / 1464
Регистрация: 14.04.2014
Сообщений: 20,671
Записей в блоге: 21
12.12.2020, 22:54
Лучший ответ Сообщение было отмечено aes2109 как решение

Решение

вот зачем столько всего если достаточно добавить просто три строчки
Delphi
1
2
3
4
s := dBF1.GetFieldData(5);
if length(s) = 8 then
  insert(s, 7, '19');
Table2.FieldByName('bdate').AsDateTime:=StrToDate(s);
0
0 / 0 / 0
Регистрация: 26.05.2013
Сообщений: 20
14.12.2020, 08:45  [ТС]
Последний вариант не работает к сожалению, так как людей, родившихся в 2001 году, он будет делать в 1901
0
Модератор
 Аватар для D1973
9924 / 6460 / 2457
Регистрация: 21.01.2014
Сообщений: 27,410
Записей в блоге: 3
14.12.2020, 09:40
aes2109, ну а самому додумать? Если год из полученной даты (2 цифры) больше числа из последних 2-х цифр текущего года - добавлять '20', меньше - '19'.
Delphi
1
2
3
4
5
6
7
8
9
10
uses ..., DateUtils;
...
var y1, y2: integer;
s := dBF1.GetFieldData(5);
if length(s) = 8 then begin
  y1 := StrToInt(Copy(s, 7, 2));
  y2 := YearOf(Now) mod 100;
  if y1 < y2 then insert(s, 7, '19') else insert(s, 7, '20');
end;
Table2.FieldByName('bdate').AsDateTime:=StrToDate(s);
0
0 / 0 / 0
Регистрация: 26.05.2013
Сообщений: 20
15.12.2020, 16:49  [ТС]
А если человеку больше 100 лет?
0
Модератор
 Аватар для D1973
9924 / 6460 / 2457
Регистрация: 21.01.2014
Сообщений: 27,410
Записей в блоге: 3
16.12.2020, 05:30
И много Вы в своей жизни встречали людей старше 100 лет? Я живу уже почти 50 лет и за все это время встречал лично только одного такого человека... Это исчезающе малая величина, которой можно пренебречь при первоначальном вводе, но оставить возможность корректировки этого поля: ввести, как 2010, тут же откорректировать вручную на 1910...
0
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,507
16.12.2020, 08:57
Написал маленькую программку, вроде как все даты считываются нормально (при клике на кнопку выводится дата из текущей записи).
Вложения
Тип файла: zip dbf.zip (5.9 Кб, 17 просмотров)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
16.12.2020, 08:57
Помогаю со студенческими работами здесь

Считать из файла дату и время в разные переменные
Друзья, у меня есть необычный текстовый файл. Он состоит из одной строчки: 29.12.2013,10:00:00 когда я читаю этот файл...

Считать таблицу из файла
Добрый день, у меня есть готовая программа - табличный редактор. Помогите сделать так чтоб он мог считать прошлую таблицу из файла и на ее...

Считать данные с файла, и создать таблицу
Задача такая, из тестового документа, или таблицы Excel забрать строку и массив, затем создать таблицу в бд используя строку как имя...

Как считать данные с файла и сгенерировать из них таблицу
Помогите пожалуйста Нужно считать файл с n числами и построить из него таблицу где x - элемент массива, n - частота повторений элемента ...

Нужно считать с файла значения и заполнить ними таблицу
MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { ui-&gt;setupUi(this); ...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Оттенки серого
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
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru