Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 22.06.2010, 14:28
-=mIx=- -=mIx=- вне форума
Прохожий
 
Регистрация: 18.05.2007
Сообщения: 8
Репутация: 10
Вопрос Как вычислить стаж работы ?

Здравствуйте.
Существует программа с базой сотрудников, есть информация о дате приема. Необходимо вычислить стаж работы на текущую дату.
Пробовал так: stazh:=date-Form1.Table1.FieldByName('Prinyat').Value; но результат не очень похож на стаж )
Заранее спасибо.
Ответить с цитированием
  #2  
Старый 22.06.2010, 14:54
Rat Rat вне форума
Активный
 
Регистрация: 12.09.2008
Сообщения: 391
Репутация: 6078
По умолчанию

Расчет кол-ва дней между датами:
Код:
Label1.Caption := IntToStr(DaysBetween(DateTimePicker1.Date, DataTimePicker2.Date));
Ответить с цитированием
  #3  
Старый 22.06.2010, 15:14
-=mIx=- -=mIx=- вне форума
Прохожий
 
Регистрация: 18.05.2007
Сообщения: 8
Репутация: 10
По умолчанию

Благодарю за ответ, но можно по подробнее?
Первая дата берется из таблицы следующим образом: Table1.FieldByName('Prinyat').Value. Вторая - текущая дата, берется из системного времени.
Результат выводится по нажатию кнопки, но это не так важно.
Спасибо.
Ответить с цитированием
  #4  
Старый 22.06.2010, 15:17
Аватар для Marvel
Marvel Marvel вне форума
Начинающий
 
Регистрация: 14.06.2010
Адрес: Пятигорск
Сообщения: 121
Репутация: 24
По умолчанию

наверное так
Код:
Label1.Caption := IntToStr(DaysBetween(Table1.FieldByName('Prinyat').AsDateTime, Now));
__________________
Коли навчався в школі я - в мені росли мозгЫ. КудИж вони поділися? гы-гы гы-гы гы-гы...


ICQ: 593977748
Nick: Marvel
Ответить с цитированием
  #5  
Старый 22.06.2010, 15:26
-=mIx=- -=mIx=- вне форума
Прохожий
 
Регистрация: 18.05.2007
Сообщения: 8
Репутация: 10
По умолчанию

Что то не получается.
Стаж между 10.06.2010 и 22.06.2010 вычисляет равным 30.12.1899
В чем может быть проблема?
Ответить с цитированием
  #6  
Старый 22.06.2010, 16:06
Аватар для Kailon
Kailon Kailon вне форума
Активный
 
Регистрация: 06.06.2010
Сообщения: 339
Версия Delphi: 10.4
Репутация: 429
По умолчанию

А у меня работает... Мож у тебя дата в таблице как-то неверно записана?
__________________
Всегда пишите код так, будто сопровождать его будет склонный к насилию психопат, который знает, где вы живете.

Последний раз редактировалось Kailon, 22.06.2010 в 16:14.
Ответить с цитированием
  #7  
Старый 22.06.2010, 17:08
Black Raider Black Raider вне форума
Местный
 
Регистрация: 31.05.2010
Адрес: Москва
Сообщения: 466
Версия Delphi: 7
Репутация: 40
По умолчанию

Код:
stazh:=now()-Form1.Table1.FieldByName('Prinyat').Value;

вообще странно что так не сработало. должно было показать разницу в днях.
представление даты есть вещественное число.
так что как тут сказали может в таблице все таки как то дата покасячилась?
Ответить с цитированием
  #8  
Старый 25.06.2010, 00:42
Аватар для Kailon
Kailon Kailon вне форума
Активный
 
Регистрация: 06.06.2010
Сообщения: 339
Версия Delphi: 10.4
Репутация: 429
По умолчанию

Выкладывай исходник и базу, посмотрим.
P.S. если не жалко
__________________
Всегда пишите код так, будто сопровождать его будет склонный к насилию психопат, который знает, где вы живете.
Ответить с цитированием
  #9  
Старый 25.06.2010, 02:44
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,034
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Цитата:
Сообщение от -=mIx=-
Что то не получается.
Стаж между 10.06.2010 и 22.06.2010 вычисляет равным 30.12.1899
В чем может быть проблема?

Проблема в отображении.
У тебя реультат отображается в формате даты-времени.
А вообще, глянь в модуль DateUtils - там есть куча функций для вычисления разницы между датами.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 06:56.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter