ABAP 计算时间差

在这里插入图片描述

在这里插入图片描述

源码
FUNCTION zfm_date_difference.
*“----------------------------------------------------------------------
"“本地接口:
*” IMPORTING
*” VALUE(IV_DATE_BEG) TYPE SY-DATUM
*" VALUE(IV_TIME_BEG) TYPE SY-UZEIT
*" VALUE(IV_DATE_END) TYPE SY-DATUM
*" VALUE(IV_TIME_END) TYPE SY-UZEIT
*" EXPORTING
*" VALUE(EV_MESSAGE) TYPE CHAR100
*"----------------------------------------------------------------------

DATA: lv_timediff TYPE t,
lv_date_b TYPE d,
lv_date_s TYPE d,
lv_time_b TYPE t,
lv_time_s TYPE t.

DATA: lv_diff_d TYPE p, "天数差
lv_diff_h TYPE p, "小时数差
lv_diff_m TYPE p, "分钟数差
lv_diff_s TYPE p, "秒数差
lv_diff_s_all TYPE p, "总秒数差
lv_diff_s_exh TYPE p. "除去小时秒数的秒数

*–1.计算天数差使用函数’SD_DATETIME_DIFFERENCE’有误(20210507 230000 - 20210507 000000)

IF iv_date_beg = iv_date_end.
lv_diff_d = 0.
IF iv_time_end > iv_time_beg.
lv_time_b = iv_time_end.
lv_time_s = iv_time_beg.
ELSE.
lv_time_b = iv_time_beg.
lv_time_s = iv_time_end.
ENDIF.

ELSEIF iv_date_beg > iv_date_end.
lv_date_b = iv_date_beg.
lv_date_s = iv_date_end.
lv_time_b = iv_time_beg.
lv_time_s = iv_time_end.

ELSEIF iv_date_beg < iv_date_end.
lv_date_b = iv_date_end.
lv_date_s = iv_date_beg.
lv_time_b = iv_time_end.
lv_time_s = iv_time_beg.

ENDIF.

lv_timediff = lv_time_b - lv_time_s.
IF lv_timediff > lv_time_b AND iv_date_beg <> iv_date_end.
lv_diff_d = lv_date_b - lv_date_s - 1.

ELSEIF lv_timediff = lv_time_b AND iv_date_beg <> iv_date_end.
lv_diff_d = lv_date_b - lv_date_s .

ELSEIF lv_timediff < lv_time_b AND iv_date_beg <> iv_date_end.
lv_diff_d = lv_date_b - lv_date_s .

ENDIF.

lv_diff_s_all = lv_time_b+0(2) * 3600 + lv_time_b+2(2) * 60 + lv_time_b+4(2) -
lv_time_s+0(2) * 3600 - lv_time_s+2(2) * 60 - lv_time_s+4(2) .

lv_diff_h = floor( abs( lv_diff_s_all ) / 3600 ).

lv_diff_s_exh = abs( abs( lv_diff_s_all ) - abs( lv_diff_h * 3600 ) ).

lv_diff_m = floor( lv_diff_s_exh / 60 ) .

lv_diff_s = abs( lv_diff_s_exh - lv_diff_m * 60 ).

IF lv_diff_s_all < 0.
lv_diff_h = 23 - lv_diff_h.
lv_diff_m = 59 - lv_diff_m.
lv_diff_s = 60 - lv_diff_s.
ENDIF.

ev_message = lv_diff_d && ‘天’ && lv_diff_h && ‘时’ &&
lv_diff_m && ‘分’ && lv_diff_s && ‘秒’.

ENDFUNCTION.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

放弃幻想_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值