ABAP生成四位流水码

用se37创建函数znumc4_initial。
源代码如下:

FUNCTION znumc4_initial.
*"----------------------------------------------------------------------
*"*"本地接口:
*"  IMPORTING
*"     VALUE(TOYEAR) TYPE  INRI-TOYEAR
*"     VALUE(SUBOBJECT) OPTIONAL
*"  TABLES
*"      LT_NRIV STRUCTURE  NRIV OPTIONAL
*"----------------------------------------------------------------------

  DATA: mod      TYPE i ,
        str      TYPE string,
        xstrc    TYPE x,
        xstr     TYPE xstring ,
        days     TYPE i,
        range_nr TYPE inri-nrrangenr.
  DO 366 TIMES.
    CLEAR: str,xstr,xstrc.
    days = sy-index .

    WHILE days > 0 .
      mod = days MOD 26 .
      days = days DIV 26 .
      IF mod = 0.
        mod = 26.
        days = days - 1.
      ENDIF.
      xstrc = mod + 64 .
      CONCATENATE xstrc xstr INTO xstr IN BYTE MODE.
      IF days < 26 AND days > 0 .
        xstrc = days + 64 .
        CONCATENATE xstrc xstr INTO xstr IN BYTE MODE.
        EXIT.
      ENDIF.
    ENDWHILE.

    CALL FUNCTION 'ECATT_CONV_XSTRING_TO_STRING'
      EXPORTING
        im_xstring  = xstr
        im_encoding = '8400'
      IMPORTING
        ex_string   = str.
    range_nr = str.
    IF strlen( range_nr ) = 1.
      range_nr = '0' && range_nr.
    ENDIF.

    lt_nriv-object = 'ZNUM4'.
    lt_nriv-subobject = subobject.
    lt_nriv-nrrangenr = range_nr.
    lt_nriv-toyear = toyear.
    lt_nriv-fromnumber = '0001'.
    lt_nriv-tonumber   = '9999'.
    lt_nriv-nrlevel = 0 .
    APPEND lt_nriv.
  ENDDO.

  MODIFY nriv FROM TABLE lt_nriv.
ENDFUNCTION.

用se37创建函数ZNUMC4_GET_NEXT。
源代码如下:

FUNCTION znumc4_get_next.
*"----------------------------------------------------------------------
*"*"本地接口:
*"  IMPORTING
*"     VALUE(DATUM) TYPE  SY-DATUM DEFAULT SY-DATUM
*"     VALUE(SUBOBJECT)
*"  EXPORTING
*"     REFERENCE(NUMBER)
*"  EXCEPTIONS
*"      INTERVAL_NOT_FOUND
*"      NUMBER_RANGE_NOT_INTERN
*"      OBJECT_NOT_FOUND
*"      QUANTITY_IS_0
*"      QUANTITY_IS_NOT_1
*"      INTERVAL_OVERFLOW
*"      BUFFER_OVERFLOW
*"      TOYEAR_NOT_FOUND
*"----------------------------------------------------------------------

  DATA: mod      TYPE i ,
        str      TYPE string,
        xstrc    TYPE x,
        xstr     TYPE xstring ,
        days     TYPE i,
        day01    TYPE d,
        range_nr TYPE inri-nrrangenr.

  IF datum IS INITIAL .
    datum = sy-datum.
  ENDIF.

  SELECT SINGLE * FROM nriv
    WHERE object = 'ZNUM4' AND
          subobject = subobject AND
          toyear = datum+0(4) .
  IF sy-subrc <> 0.
    RAISE toyear_not_found.
  ENDIF.

  day01 = datum+0(4) && '0101'.
  days = datum - day01 + 1.

  WHILE days > 0 .
    mod = days MOD 26 .
    days = days DIV 26 .
    IF mod = 0.
      mod = 26.
      days = days - 1.
    ENDIF.
    xstrc = mod + 64 .
    CONCATENATE xstrc xstr INTO xstr IN BYTE MODE.
    IF days < 26 AND days > 0 .
      xstrc = days + 64 .
      CONCATENATE xstrc xstr INTO xstr IN BYTE MODE.
      EXIT.
    ENDIF.
  ENDWHILE.

  CALL FUNCTION 'ECATT_CONV_XSTRING_TO_STRING'
    EXPORTING
      im_xstring  = xstr
      im_encoding = '1106'
    IMPORTING
      ex_string   = str.
  range_nr = str.
  IF strlen( range_nr ) = 1.
    range_nr = '0' && range_nr.
  ENDIF.

  CALL FUNCTION 'NUMBER_GET_NEXT'
    EXPORTING
      nr_range_nr             = range_nr
      object                  = 'ZNUM4'
      subobject               = subobject
      toyear                  = datum+0(4)
    IMPORTING
      number                  = number
    EXCEPTIONS
      interval_not_found      = 1
      number_range_not_intern = 2
      object_not_found        = 3
      quantity_is_0           = 4
      quantity_is_not_1       = 5
      interval_overflow       = 6
      buffer_overflow         = 7
      OTHERS                  = 8.
  CASE sy-subrc.
    WHEN 1.
      RAISE interval_not_found.
    WHEN 2.
      RAISE number_range_not_intern.
    WHEN 3.
      RAISE object_not_found.
    WHEN 4.
      RAISE quantity_is_0.
    WHEN 5.
      RAISE quantity_is_not_1.
    WHEN 6.
      RAISE interval_overflow.
    WHEN 7.
      RAISE buffer_overflow.
    WHEN OTHERS.
  ENDCASE.
ENDFUNCTION.

使用方法:

 DATA: numc(4) TYPE n.
 CALL FUNCTION 'ZNUMC4_GET_NEXT'
          EXPORTING
            subobject = '02'
          IMPORTING
            number    = numc
          EXCEPTIONS
            OTHERS    = 9.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352

推荐阅读更多精彩内容