您的位置:首页 > 其它

SAP中日期时间函数总结

2013-07-25 14:04 260 查看
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_DAYS和I_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周的第一天是3月28日。

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、获取一年的第几周和这个周一和周日的日期

FM:GET_WEEK_INFO_BASED_ON_DATE

输入参数 值

DATE 2008.01.09

输出参数 值

WEEK 200802 <----2008年第二周

MONDAY 2008.01.07 <----这个周周一的日期

SUNDAY 2008.01.13 <----周日的日期

11、输入日期是星期几

FM:DAY_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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: