SAP Tutorials Blog


 

 


DATA time4calc TYPE t VALUE '115708'.

DATA(seconds_total) = CONV i( time4calc ). "43028

DATA(calc_hours) = seconds_total DIV 3600. "11

DATA(min_calc) = ( seconds_total - calc_hours * 3600 ) DIV 60. "57

DATA(sec_calc) = ( seconds_total - calc_hours * 3600 ) - min_calc * 60. "8


"Using the XCO library

"See the snippet above in the date section as well as the class documentation.

"Adding

"e.g. 16:27:34 (if the current time is 15:26:33)

DATA(time_xco_add) = xco_cp=>sy->time( xco_cp_time=>time_zone->user

                                      )->add( iv_hour = 1 iv_minute = 1 iv_second = 1

                                      )->as( xco_cp_time=>format->iso_8601_extended

                                      )->value.

"Subtracting

"e.g. 14:27:45 (if the current time is 15:28:46)

DATA(time_xco_subtr) = xco_cp=>sy->time( xco_cp_time=>time_zone->user

                                       )->subtract( iv_hour = 1 iv_minute = 1 iv_second = 1

                                       )->as( xco_cp_time=>format->iso_8601_extended

                                       )->value.


*&---------------------------------------------------------------------*

*& Calculating the time delta between two time values

*&---------------------------------------------------------------------*


DATA: time1 TYPE t VALUE '210000',

      time2 TYPE t VALUE '040000'.


"Calculating the time difference by subtracting

"Note that the resulting data object is of type i.

"The time values are automatically converted to type i.

"Following the conversion rule of type t to i, the resulting value

"is calculated as follows: format hhmmss of type t -> integer values

"as a result of the calculation hh * 3600 + mm * 60 + ss.


"-61200

DATA(time_diff) = time2 - time1.


"75600

DATA(time1_conv2i) = CONV i( time1 ).

ASSERT time1_conv2i = ( 21 * 3600 ) + ( 00 * 60 ) + 00.


"14400

DATA(time2_conv2i) = CONV i( time2 ).

ASSERT time2_conv2i = ( 04 * 3600 ) + ( 00 * 60 ) + 00.

ASSERT time2_conv2i - time1_conv2i = time_diff.


*&----------------------------------------------------------------------------------*

*& Calculating the total values of the time difference in seconds, minutes and hours

*&----------------------------------------------------------------------------------*


"The MOD operator is used and works in a way that the positive remainder

"of the division of the left operand by the right is returned. Therefore,

"it is irrelevant whether the time difference value is either positive or

"negative.

"The value 86400 is used as right operand, representing the number of seconds

"per day/24 hours.

"25200

DATA(time_diff_seconds_total) = ( time2 - time1 ) MOD 86400.


"120.05

DATA(time_diff_minutes_total) = CONV decfloat34( ( ( time2 - time1 ) MOD 86400 ) / 60 ).


"2.000833333333333333333333333333333

DATA(time_diff_hours_total) = CONV decfloat34( ( ( ( time2 - time1 ) MOD 86400 ) / 3600 ) ).


"---- Representing the time difference in a data object of type t ----

DATA diff_time TYPE t.


DATA(diff) = ( time2 - time1 ) MOD 86400.


"The following calculations use the DIV operator

"This operator returns the integer part of the division of the left operand

"by the right

DATA(hours) = diff DIV 3600.

diff = diff MOD 3600.

DATA(minutes) = diff DIV 60.

DATA(seconds) = diff MOD 60.


"diff_time: '070000'

diff_time(2) = hours.

diff_time+2(2) = minutes.

diff_time+4(2) = seconds.


"More examples

time1 = '225958'.

time2 = '010001'.


"diff_time: '020003'

diff_time(2) = ( ( time2 - time1 ) MOD 86400 ) DIV 3600.

diff_time+2(2) = ( ( ( time2 - time1 ) MOD 86400 ) MOD 3600 ) DIV 60.

diff_time+4(2) = ( ( ( time2 - time1 ) MOD 86400 ) MOD 3600 ) MOD 60.


time1 = '010001'.

time2 = '225958'.


"diff_time: '215957'

diff_time(2) = ( ( time2 - time1 ) MOD 86400 ) DIV 3600.

diff_time+2(2) = ( ( ( time2 - time1 ) MOD 86400 ) MOD 3600 ) DIV 60.

diff_time+4(2) = ( ( ( time2 - time1 ) MOD 86400 ) MOD 3600 ) MOD 60.


"diff_time: '154342'

time1 = '132415'.

time2 = '050757'.

diff_time(2) = ( ( time2 - time1 ) MOD 86400 ) DIV 3600.

diff_time+2(2) = ( ( ( time2 - time1 ) MOD 86400 ) MOD 3600 ) DIV 60.

diff_time+4(2) = ( ( ( time2 - time1 ) MOD 86400 ) MOD 3600 ) MOD 60.


time1 = '050757'.

time2 = '132415'.


"diff_time: '081618'

diff_time(2) = ( ( time2 - time1 ) MOD 86400 ) DIV 3600.

diff_time+2(2) = ( ( ( time2 - time1 ) MOD 86400 ) MOD 3600 ) DIV 60.

diff_time+4(2) = ( ( ( time2 - time1 ) MOD 86400 ) MOD 3600 ) MOD 60.


"---- Excursion: / and DIV operators (and why DIV is used above) ----

time1 = '132415'.

time2 = '050757'.


"Compare the result of the following statements that use different operators

"15

DATA(hours_w_div) = ( ( time2 - time1 ) MOD 86400 ) DIV 3600.


"16 (result of type i, result is rounded)

DATA(hours_no_div) = ( ( time2 - time1 ) MOD 86400 ) / 3600.

"15.72833333333333333333333333333333

DATA(hours_no_div_dec) = CONV decfloat34( ( ( time2 - time1 ) MOD 86400 ) / 3600 ).


Serkan AKKAVAK

Computer Engineer BSc

Head of SAP & Software Department

Contact : serkurumsal@yandex.com