SAP中日期时间函数总结

SAP中日期时间函数总结

1、获得最后一天
CALL FUNCTION 'FIMA_DATE_CREATE'
  EXPORTING
  I_DATE                      = I_DATE "
输入日期。sy-datum类型如:‘20110402’
  I_FLG_END_OF_MONTH           = ' '
   I_YEARS                      = 2 "
两年后的日期时间,既sy-datum的年加2所得日期,可为负数,表示前两年
  I_MONTHS                     = 1 "
一个月后的日期。既sy-datum的月加1所得日期,可为负数,表示前一个月
  I_DAYS                       = 23 "23
天后的日期。可为负数,表示23天前的日期
  I_CALENDAR_DAYS              = 10 "10
天后的日历。同I_DAYS参数。
   I_SET_LAST_DAY_OF_MONTH       = 'X'"
返回的日期为当前月份的最后一天
 IMPORTING
  E_DATE                       = E_DATE "
返回的日期。如果I_DAYSI_CALENDAR_DAYS都设置,则天数累加
  E_FLG_END_OF_MONTH           = FLAG     "
如果输入参数I_SET_LAST_DAY_OF_MONTH设置'X'了,则返回值为'X'
  E_DAYS_OF_I_DATE             = DAY. "
返回输入日期的字段与I_DAYS字段的和。本例子为:25
  
2、获得周数
DATA WEEK LIKE SCAL-WEEK.
CALL FUNCTION 'DATE_GET_WEEK'
  EXPORTING
   DATE              = SY-DATUM ”
输入日期,如:‘20110402’
 IMPORTING
  WEEK              = WEEK.“
返回输入日期为该年第几周。如:‘201113’。表示为2011年的第13周。

3、获得某周的第一天日期
DATA DATE LIKE SCAL-DATE.
CALL FUNCTION 'WEEK_GET_FIRST_DAY'
  EXPORTING
   WEEK              = '201113' "
表示2011年的第13
 IMPORTING
  DATE              = DATE. "
返回的DATE值为20110328,2011年第13周的第一天是328日。
  
4、得到输入日期N个月前/后的日期
4.1 返回指定月以前的日期
CALL FUNCTION 'CCM_GO_BACK_MONTHS'
  EXPORTING
    CURRDATE         =sy-datum
    BACKMONTHS       = 6
 IMPORTING
   NEWDATE          =DATE . 
4.2
返回指定年,月,日以前或以后的日期.年月日得加减
CALL FUNCTION 'RP_CALC_DATE_IN_INTERVAL'
  EXPORTING
    DATE           = sy-datum
   DAYS            = 10
    MONTHS         = 5
   SIGNUM          ='+'"
取值为‘+’‘-’
   YEARS           = 1
 IMPORTING
   CALC_DATE       = date  .

5、返回两个日期之间的年数、月数、天数
CALL FUNCTION 'FIMA_DAYS_AND_MONTHS_AND_YEARS'
  EXPORTING
   I_DATE_FROM          = '20110402'
*   I_KEY_DAY_FROM       =
   I_DATE_TO            ='20110522'
*   I_KEY_DAY_TO         =
*   I_FLG_SEPARATE       = ' '
 IMPORTING
  E_DAYS              = E_DAYS    "
值为50
  E_MONTHS            = E_MONTHS "
值为2
   E_YEARS             = E_YEARS .  "
值为1
  
6、获取输入日期月份的最后一天
BKK_GET_MONTH_LASTDAY
 EXPORTING
  I_DATE = '20110403'
 IMPORTING
  E_DATE = E_DATE. "E_DATE= '20110430'

7、日期有效性检查
 DATE_CHECK_PLAUSIBILITY

8、获得所有的月份信息
DATA MONTH_NAMES LIKE T247 OCCURS 0.
CALL FUNCTION 'MONTH_NAMES_GET'
 EXPORTING
  LANGUAGE                   = SY-LANGU
* IMPORTING
*  RETURN_CODE                =
  TABLES
   MONTH_NAMES                = MONTH_NAMES
* EXCEPTIONS
*   MONTH_NAMES_NOT_FOUND       = 1
*  OTHERS                     = 2
          .

9.弹出一个窗口显示一个日历允许用户选择一个日期
CALL FUNCTION 'F4_DATE'
 EXPORTING
  DATE_FOR_FIRST_MONTH              = SY-DATUM
  DISPLAY                           = 'X' "
如果为X则只显示日历窗口,而没有返回值
*  FACTORY_CALENDAR_ID               = ' '
*   GREGORIAN_CALENDAR_FLAG           = ' '
*  HOLIDAY_CALENDAR_ID               = ' '
*  PROGNAME_FOR_FIRST_MONTH          = ' '
 IMPORTING
  SELECT_DATE                       =  “
返回值为选择的日期
*  SELECT_WEEK                       =
*  SELECT_WEEK_BEGIN                 =
*  SELECT_WEEK_END                   =
* EXCEPTIONS
*   CALENDAR_BUFFER_NOT_LOADABLE      = 1
*  DATE_AFTER_RANGE                  = 2
*  DATE_BEFORE_RANGE                 = 3
*  DATE_INVALID                      = 4
*   FACTORY_CALENDAR_NOT_FOUND        = 5
*  HOLIDAY_CALENDAR_NOT_FOUND         = 6
*  PARAMETER_CONFLICT                = 7
*  OTHERS                            = 8   
  
10、获取一年的第几周和这个周一和周日的日期
FMGET_WEEK_INFO_BASED_ON_DATE
输入参数                       
DATE                           2008.01.09
输出参数                       
WEEK                           200802      <----2008
年第二周
MONDAY                         2008.01.07 <----
这个周周一的日期
SUNDAY                         2008.01.13 <----
周日的日期
 
11、输入日期是星期几
FMDAY_IN_WEEK
输入参数                       
DATUM                          2008.01.09
输出参数                       
WOTNR                          3           <----2008-1-9
为周三

12、弹窗选择时间
CALL 'F4_CLOCK'
 EXPORTING
  START_TIME = '15:18:20'
‘151820’"输入时可选的
  DISPLAY    =
 IMPORTING
  SELECTED_TIME = “
返回选择的时间

13年和月的选择窗口
DATA MONTH LIKE ISELLIST-MONTH.
CALL FUNCTION 'POPUP_TO_SELECT_MONTH'
  EXPORTING
   ACTUAL_MONTH                    = SY-DATUM+0(6)
*  FACTORY_CALENDAR                = ' '
*   HOLIDAY_CALENDAR                = ' '
  LANGUAGE                        = SY-LANGU
  START_COLUMN                    = 8
  START_ROW                       = 5
 IMPORTING
  SELECTED_MONTH                  = MONTH "
返回值为六位数字
*  RETURN_CODE                     =
 EXCEPTIONS
   FACTORY_CALENDAR_NOT_FOUND       = 1
   HOLIDAY_CALENDAR_NOT_FOUND       = 2
  MONTH_NOT_FOUND                 = 3
  OTHERS                          = 4  .
  
14、获取周的信息
DATA WEEKDAY LIKE T246 OCCURS 0.
CALL FUNCTION 'WEEKDAY_GET'
* EXPORTING
*  LANGUAGE               = SY-LANGU
* IMPORTING
*  RETURN_CODE            =
  TABLES
   WEEKDAY                = WEEKDAY
* EXCEPTIONS
*   WEEKDAY_NOT_FOUND       = 1
*  OTHERS                 = 2   

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值