ABAP日期处理汇总

  1. 获取指定日期往后推N个月的日期,这个函数遇到1.30推下个月的时候,会转成2.28,不会跳到3月
DATA: p_months type I value -4, p_date type D.
    CALL FUNCTION 'MONTH_PLUS_DETERMINE'
    EXPORTING
      MONTHS        = 1   #"月份
      OLDDATE       = '20220130'
    IMPORTING
      NEWDATE       = p_date.
    #"p_date的结果会是20220228
  1. 获取指定月份的最后一天
 CALL FUNCTION 'LAST_DAY_OF_MONTHS'
    EXPORTING
      DAY_IN = '20220101'
    IMPORTING
      LAST_DAY_OF_MONTH = LSTDAY_NMTH
    EXCEPTIONS
      DAY_IN_NO_DATE = 1
      OTHERS = 2.
  #:LSTDAY_NMTH 的结果会是20220131
  1. 获取指定日期的第一天
data s_date like sy-datum.
s_date = '20220202'.
s_date+6(2) = '01'.
WRITE: s_date.
  1. 根据日期计算另一个日期,可以设定间隔年月日
CALL FUNCTION 'RP_CALC_DATE_IN_INTERVAL'
   EXPORTING
      DATE            = '20220202'
      DAYS            = 1
      MONTHS          = 0
      SIGNUM          = '+'
      YEARS           = 0
   IMPORTING
      CALC_DATE       = FSTDAY_NMTH.
#    FSTDAY_NMTH = '20220203'  
  1. 日期加减
data l_date like sy-datum.  "定义类型为日期格式
l_date = sy-datum.   #定义l_date变量的值为当天
l_date = l_date + 1.   #日期+1天 


data s_date like sy-datum.
data s_date1 like sy-datum.
data s_data   type i.
s_date = '20220202'.
s_date1 = '20220205'.
s_data = s_date1 - s_date.   "得到两个日期的天数

  1. 获取日期间间隔
  CALL FUNCTION 'FIMA_DAYS_AND_MONTHS_AND_YEARS'
    EXPORTING
      I_DATE_FROM          = '20220202'
*     I_KEY_DAY_FROM  =
      I_DATE_TO                = '20220228'
*     I_KEY_DAY_TO        =
*     I_FLG_SEPARATE   = ' '
   IMPORTING
     E_DAYS                 = t_day
     E_MONTHS            = T_MOTH
     E_YEARS              =t_year
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

四方木2021

您的鼓励是我前进路上的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值