36 / 35 / 3
Регистрация: 12.06.2009
Сообщений: 211
1

Ttime,TDatetime Суммирование времени

17.10.2009, 13:00. Показов 4921. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Доброго времени суток !


Создав программку,решил добавить в неё процесс суммирования времени,но обнаружил,что после 23:59:59 ,он снова начинает идти с нуля (

(т.е. 13 часов + 13 часов = 2 часа !! (а должно быть 26 часов)

Пример кода:

Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
for a:=5 to Recnumber+2 do
  begin
  datestr:=DateToStr(DateTimePicker1.Date); //string
  Ap.Cells[a,cellnumber]:='0';
    for z:=1 to datenumbers-1 do
    begin
    try
    NAMESTR:=Ap.Cells[a,1];  //string
    TELEPHONESTR:=Ap.Cells[a,2];  //string
    MainForm.Query3.SQL.Text:='select * from "'+DBPASP+'" where NAME = "'+NAMESTR+'" and TELEPHONE = "'+TELEPHONESTR+'" and CURDATE = "'+datestr+'"';
    MainForm.Query3.open;
    datestr:=DateToStr(StrToDate(datestr)+StrToDate('31.12.1899'));  //string
    STARTTIMESTR:=MainForm.Query3.fieldbyname('STARTTIME').AsString; //string
    STOPTIMESTR:=MainForm.Query3.fieldbyname('STOPTIME').AsString; //string
    Sumtime:=Sumtime+(StrToTime(STOPTIMESTR)-StrToTime(STARTTIMESTR)); //TTIME  ..Он же и выдаёт косячное значение :(
    except end;
    Ap.Cells[a,cellnumber]:=TimeToStr(Sumtime);
    end;
  end;

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

Добавлено через 8 минут
Вопрос можно закрывать..видимо,это можно сделать только сложением через integer часов,минут и секунд...

0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
17.10.2009, 13:00
Ответы с готовыми решениями:

TDateTime - разница времени
int hh,hh1,min,min1,sec,sec1,msec,msec1; hh=StrToInt(Edit1->Text); hh1=StrToInt(Edit2->Text); ...

Суммирование времени
Не получается складывать время. $arr = array('00:01', '00:05', '00:04'); // массив времен....

Суммирование времени
Задача. Есть таблица альбом(Название), таблица Трек(название и время звучания, код альбома).Нужно...

Суммирование времени
Добрый вечер! Посмотрите, пожалуйста, в “запрос №2” там я сделал разбитие времени на часы в...

2
Эксперт С++
3071 / 1409 / 425
Регистрация: 19.01.2009
Сообщений: 3,879
17.10.2009, 13:06 2
Если вам суммировать разницу между двумя TDateTime переменными, используйте функцию HoursBetween(), а ее результат суммируюте с накапливающей переменной. Она декларирована в DateUtils. Обязатьельно почитайте "HoursBetween function" в справочной системе, там есть некоторые ремарки.
0
36 / 35 / 3
Регистрация: 12.06.2009
Сообщений: 211
17.10.2009, 14:19  [ТС] 3
polivets,
Спасибо,но я уже решил

Delphi
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
//SUMTIME
if CheckBox1.Checked then
begin
//Ap.Cells[5,cellnumber]:='START';
//Ap.Cells[Recnumber+2,cellnumber]:='END';
  for a:=5 to Recnumber+2 do
  begin
  datestr:=DateToStr(DateTimePicker1.Date);
  time1:=0;
  time2:=0;
  time3:=0;
    for z:=1 to datenumbers-1 do
    begin
    try
    NAMESTR:=Ap.Cells[a,1];
    TELEPHONESTR:=Ap.Cells[a,2];
    MainForm.Query3.SQL.Text:='select * from "'+DBPASP+'" where NAME = "'+NAMESTR+'" and TELEPHONE = "'+TELEPHONESTR+'" and CURDATE = "'+datestr+'"';
    MainForm.Query3.open;
    datestr:=DateToStr(StrToDate(datestr)+StrToDate('31.12.1899'));
    STARTTIMESTR:=MainForm.Query3.fieldbyname('STARTTIME').AsString;
    STOPTIMESTR:=MainForm.Query3.fieldbyname('STOPTIME').AsString;
    Sumtime:=StrToTime(STOPTIMESTR)-StrToTime(STARTTIMESTR);
    time1:=time1+HourOf(Sumtime);
    time2:=time2+MinuteOf(Sumtime);
    time3:=time3+SecondOf(Sumtime);
    except end;
    end;
  if TIME1 < 10 then CELLTEMP:='0'+IntToStr(time1) else CELLTEMP:=IntToStr(time1);
  if TIME2 < 10 then CELLTEMP:=CELLTEMP+':0'+IntToStr(time2) else CELLTEMP:=CELLTEMP+':'+IntToStr(time2);
  if TIME3 < 10 then CELLTEMP:=CELLTEMP+':0'+IntToStr(time3) else CELLTEMP:=CELLTEMP+':'+IntToStr(time3);
  Ap.Cells[a,cellnumber]:=CELLTEMP;
  end;
end;
//SUMTIME
0
17.10.2009, 14:19
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.10.2009, 14:19
Помогаю со студенческими работами здесь

Суммирование значений времени
Здравствуйте! Возникла сложность при суммировании значений времени. Программно вставляю в файл...

Суммирование времени в столбце
Добрый день! Есть детализация счета где указано время в столбце вида: 0:34 (ноль минут, 34 секунды)...

Суммирование поля формата времени
Добрый день! Есть таблица с видеофайлами, в таблице поле формата &quot;длинный формат времени&quot;, где...

Подскажите, пожалуйста, как сделать суммирование чисел в реальном времени?
Подскажите пожалуйста, как сделать суммирование чисел в реальном времени. То есть запускаю...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru