码迷,mamicode.com
首页 > 其他好文 > 详细

abap中,利用write进行表单打印示例

时间:2015-04-23 10:54:09      阅读:195      评论:0      收藏:0      [点我收藏+]

标签:abap中   利用write进行表单打印示例   

 

*&---------------------------------------------------------------------*
*& Report  Z_PRINT_LEND                                                *
*&                                                                     *
*&---------------------------------------------------------------------*
*&developer : liuxy
*&date      : 2015.04.23
*&                                                                     *
*&---------------------------------------------------------------------*

REPORT  Z_PRINT_LEND NO STANDARD PAGE HEADING."借还物台帐

TABLES : ZLEND_MAIN,ZLEND_DETAIL,ZRETURN_INFOR,ZRENEW_INFOR,ZLEND_LL.
TABLES : SSCRFIELDS , ZT016T."用于按钮的]字段属性
DATA : FLAG TYPE C.
DATA : LEND_MAIN LIKE ZLEND_MAIN OCCURS 0 WITH HEADER LINE.
DATA : LEND_DETAIL LIKE ZLEND_DETAIL OCCURS 0 WITH HEADER LINE.
DATA : RETURN_DATA LIKE ZRETURN_INFOR OCCURS 0 WITH HEADER LINE.
DATA : LEND_LL LIKE ZLEND_LL OCCURS 0 WITH HEADER LINE.
DATA : LEND_LL2 LIKE ZLEND_LL OCCURS 0 WITH HEADER LINE.
DATA : ITAB(72OCCURS 0 WITH HEADER LINE.
DATA : P_PRO(10) ,LLD_NO(10) , HLD_NO(10) ,TT TYPE C,P_PRY(10).
DATA : NUM,NUM2(20),P_NUM ,NUM3(20TYPE I.
DATA : APPLY_NUM , GET_NUM ,RET_NUM LIKE ZLEND_DETAIL-APPLY_NUM .
DATA : P_NO LIKE ZRETURN_INFOR-RETURN_NO ."用于记录还物单号
DATA : S_STORE(10) ,NAME(20) ,NAME2(20TYPE C.
TYPE-POOLS: SLIS.
DATA: FIELDCAT  TYPE SLIS_T_FIELDCAT_ALV WITH HEADER LINE.
DATABEGIN OF INFOR_ALL OCCURS 0,"用于记录所有信息
*        MANDT    like zlend_detail-mandt,"集团
*        line_no  like zlend_detail-line_no ,"行号
        LEND_NO  LIKE ZLEND_DETAIL-LEND_NO ,"借料单号码
        MATNR    LIKE ZLEND_DETAIL-MATNR,"物料号
        STORE_TYPE LIKE ZLEND_DETAIL-STORE_TYPE,"库类别
        PROPERTY LIKE ZLEND_DETAIL-PROPERTY,"属性
        MEINS    LIKE ZLEND_DETAIL-MEINS,"计量单位
        APPLY_NUM  LIKE ZLEND_DETAIL-APPLY_NUM,"申请数量
        PRICE    LIKE ZLEND_DETAIL-PRICE,"单价
*        total    like zlend_detail-price,"总金额
        TOTAL    TYPE  I,"总计显示
        APPLY_NO LIKE ZLEND_DETAIL-APPLY_NO,"申请单号
        NUM      LIKE ZLEND_DETAIL-APPLY_NUM,"拖欠数量
        GET_NUM  LIKE ZLEND_DETAIL-GET_NUM,"得到数量
        SENDER   LIKE ZLEND_DETAIL-SENDER,"发货人
        STORER   LIKE ZLEND_DETAIL-SOTRER,"库管人员  输入用
        MACHI_SERIES  LIKE ZLEND_DETAIL-MACHI_SERIES ,"机器序列号
        RETURN_NUM LIKE ZLEND_DETAIL-RETURN_NUM,"归还数量
        LAST_DATE  LIKE ZLEND_DETAIL-LAST_DATE,"最后一次的操作日期
        STATUS   LIKE ZLEND_DETAIL-STATUS,"状态
        MAKTX    LIKE ZLEND_DETAIL-MAKTX,"物料描述
        SERIES   LIKE ZLEND_DETAIL-SERIES,"规格型号
        ZTBS     LIKE ZLEND_DETAIL-ZTBS,"在途标示
        CHECKS   TYPE C,"detail information
        LEND_DEPART LIKE ZLEND_MAIN-LEND_DEPART,"nomber
        LEND_DEP    LIKE ZLEND_MAIN-DEP_DETAIL,
        DEP_DETAIL  LIKE ZLEND_MAIN-DEP_DETAIL,"部门详述
        LEND_DATE   LIKE ZLEND_MAIN-LEND_DATE,
        RETURN_DATE LIKE ZLEND_MAIN-RETURN_DATE,
        PURPOSE     LIKE ZLEND_MAIN-PURPOSE,
        PUR_DETAIL  LIKE ZLEND_MAIN-PUR_DETAIL,
        MANAGER1    LIKE ZLEND_MAIN-MANAGER1,
*        manager2    like zlend_main-manager2,
*        storer      like zlend_main-storer,
        OPERATOR    LIKE ZLEND_MAIN-OPERATOR,
        LENDER      LIKE ZLEND_MAIN-LENDER,
        OVER_DAY   TYPE I,
        RETURN_NO  LIKE ZLEND_DETAIL-LEND_NO,
*        have_date  like zreturn_infor-return_date,
        " 用于记录超期天数
      END OF INFOR_ALL.
DATA : RETURN_DAT LIKE ZRETURN_INFOR OCCURS 0 WITH HEADER LINE.
DATA : LEND_NUM(16TYPE I .
DATA:S TYPE I,
     S2 TYPE I.


SELECTION-SCREEN BEGIN OF BLOCK RAD1 WITH FRAME TITLE T1."ADD group
SELECTION-SCREEN BEGIN OF LINE."添加选项 借物台帐
SELECTION-SCREEN COMMENT 1(20) T11.
PARAMETERS LEND  RADIOBUTTON GROUP RAD1 .
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN BEGIN OF LINE."还物台帐
SELECTION-SCREEN COMMENT 1(20) T12.
PARAMETERS RETURN RADIOBUTTON GROUP RAD1 .
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN END OF BLOCK RAD1.        " end of group

*selection-screen begin of block che1 with frame title T7." add checbox
SELECTION-SCREEN BEGIN OF BLOCK RAD2 WITH FRAME TITLE T5."ADD GROUP 2

SELECTION-SCREEN BEGIN OF LINE."逾期未还借物的用途分类统计表
SELECTION-SCREEN COMMENT 1(20) T52."已还借物信息lend_main,
"lend_detail
PARAMETERS OVER_PUR RADIOBUTTON GROUP RAD2.
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN BEGIN OF LINE."已还物库信息统计
SELECTION-SCREEN COMMENT 1(20) T54."
PARAMETERS RETU_DAT RADIOBUTTON GROUP RAD2 .
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN BEGIN OF LINE."按照归还日期统计
SELECTION-SCREEN COMMENT 1(20) T55."
PARAMETERS P_DATE RADIOBUTTON GROUP RAD2 .
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN BEGIN OF LINE."各月借物统计表
SELECTION-SCREEN COMMENT 1(20) T53."未还信息
PARAMETERS MON_DAT RADIOBUTTON GROUP RAD2 DEFAULT ‘X‘.
SELECTION-SCREEN END OF LINE.

SELECTION-SCREEN END OF BLOCK RAD2." END OF GROUP 2


SELECTION-SCREEN BEGIN OF BLOCK RAD3 WITH FRAME TITLE T7.
" begin of print
SELECTION-SCREEN BEGIN OF LINE."借物单打印
SELECTION-SCREEN COMMENT 1(20) T14.
*    parameters c_lend as checkbox.
PARAMETERS C_LEND  RADIOBUTTON GROUP RAD3.
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN BEGIN OF LINE."还料单打印
SELECTION-SCREEN COMMENT 1(20) T15.
*    parameters c_retu as checkbox .
PARAMETERS C_RETU RADIOBUTTON GROUP RAD3.
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN BEGIN OF LINE."领料单打印
SELECTION-SCREEN COMMENT 1(20) T16.
PARAMETERS C_LLD  RADIOBUTTON GROUP RAD3.
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN END OF BLOCK RAD3.

SELECTION-SCREEN BEGIN OF LINE."借物日期选项
SELECTION-SCREEN COMMENT 1(20) T2.
SELECT-OPTIONS L_DATE FOR ZLEND_MAIN-LEND_DATE.
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN BEGIN OF LINE."归还日期选项
SELECTION-SCREEN COMMENT 1(20) T6.
SELECT-OPTIONS R_DATE FOR ZLEND_MAIN-RETURN_DATE.
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN BEGIN OF LINE."部门选项
SELECTION-SCREEN COMMENT 1(20) T3.
*  PARAMETERS DEPART(20) TYPE C.
*  PARAMETERS : DEPART LIKE T016T-BRSCH .
SELECT-OPTIONS  DEPART FOR ZT016T-BRSCH .
SELECTION-SCREEN END OF LINE.

SELECTION-SCREEN BEGIN OF LINE.
SELECTION-SCREEN COMMENT 1(23) T4.
PARAMETERS PERMIT(8) ."审批人
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN BEGIN OF LINE.
SELECTION-SCREEN COMMENT 1(20) T8.
*  PARAMETERS NO(10) ."借料单号
SELECT-OPTIONS NO FOR ZLEND_DETAIL-LEND_NO .
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN BEGIN OF LINE.
SELECTION-SCREEN COMMENT 1(20) T9.
*  PARAMETERS R_NO(10) ."还料单好
SELECT-OPTIONS R_NO FOR ZRETURN_INFOR-RETURN_NO.
SELECTION-SCREEN END OF LINE.

INITIALIZATION.

  T1 =  ‘台帐选项‘.
  T11 = ‘借物台帐‘.

  T12 = ‘单据打印‘.

  T14 = ‘借料单打印‘.
  T15 = ‘还料单打印‘.
  T16 = ‘领料单打印‘.
  T2 =  ‘请选择借料日期:‘.
  T3 = ‘部门选项:‘.
  T4 = ‘审批人:‘.
  T5 = ‘具体分类信息‘.

  T52 = ‘已还借物统计表‘.
  T54 = ‘已还批次统计表‘.
  T55 = ‘按归还日期统计‘.
  T53 = ‘未还借物统计表‘.

  T6 = ‘请选择还物日期:‘.
  T7 = ‘单据种类选项:‘.
  T8 = ‘借料单号:‘.
  T9 = ‘还料单号:‘.

AT SELECTION-SCREEN.

  CLEAR ITAB[].



  IF PERMIT <> ‘‘.
    IF ITAB IS INITIAL.
      CONCATENATE ‘manager1 = ‘ ‘ permit ‘ INTO ITAB.
    ELSE.
      CONCATENATE ‘ and manager1 = ‘ ‘ permit ‘ INTO ITAB.
    ENDIF.
    APPEND ITAB.
  ENDIF.
*  if NO <> ‘‘ .
*     if itab is initial.
*       concatenate ‘lend_no = ‘ ‘ NO ‘ into itab .
*     else.
*       concatenate ‘ and lend_no = ‘ ‘ NO ‘ into itab.
*     endif.
*     append itab.
*  endif.


*  if SY-UNAME = ‘LIUSHENG‘ .
*    if itab is initial.
*      concatenate ‘operator = ‘ ‘ sy-uname ‘ into itab.
*    else.
*      concatenate ‘ and operator = ‘ ‘ sy-uname ‘ into itab.
*    endif.
*    append itab.
*  endif.
*  if SY-UNAME = ‘NIEJIAN‘ .
*    if itab is initial.
*      concatenate ‘operator = ‘ ‘ sy-uname ‘ into itab.
*    else.
*      concatenate ‘ and operator = ‘ ‘ sy-uname ‘ into itab.
*    endif.
*    append itab.
*  endif.
  IF SY-UNAME = ‘LIUQJ‘.
    IF ITAB IS INITIAL.
      CONCATENATE ‘operator = ‘ ‘ sy-uname ‘ INTO ITAB.
    ELSE.
      CONCATENATE ‘ and operator = ‘ ‘ sy-uname ‘ INTO ITAB.
    ENDIF.
    APPEND ITAB.
  ENDIF.

START-OF-SELECTION.
*  set pf-status ‘LEND01‘.
END-OF-SELECTION.

  IF LEND =  ‘X‘.
    IF MON_DAT = ‘X‘.
      PERFORM LEND_DATA."未还信息
    ELSEIF RETU_DAT = ‘X‘.
      PERFORM RETURN_DATA."已还批次
    ELSEIF P_DATE = ‘X‘."按归还时间统计
      PERFORM TIME_DATA.
    ELSEIF OVER_PUR = ‘X‘.
      PERFORM PUR_DATA."已还信息
    ENDIF.
  ENDIF.
  IF RETURN = ‘X‘.
    PERFORM RETU_DAT.
  ENDIF.



*&--------------------------------------------------------------------*
*&      Form  LEND_DATA
*&--------------------------------------------------------------------*
*       text
*---------------------------------------------------------------------*
FORM LEND_DATA."借物台帐未还信息
  IF SY-UNAME = ‘YINGZHAO‘ OR SY-UNAME = ‘ZHANGSHP‘ OR SY-UNAME =
‘YAOLJ‘.
    NAME = ‘2000‘.
    IF ITAB IS INITIAL.
      CONCATENATE ‘LEND_DEPART = ‘ ‘ NAME ‘INTO ITAB.
    ELSE.
      CONCATENATE ‘ AND LEND_DEPART = ‘ ‘ NAME ‘INTO ITAB.
    ENDIF.
    APPEND ITAB.
    CLEAR DEPART.
  ENDIF.
*  if depart <> ‘‘ .
*    if itab is initial.
*        concatenate ‘lend_depart = ‘ ‘ depart ‘ into itab.
*    else.
*       concatenate ‘ and lend_depart = ‘ ‘ depart ‘ into itab.
*    endif.
*    append itab.
*  endif.
  CLEAR LEND_MAIN[].
  CLEAR LEND_DETAIL[].
  CLEAR INFOR_ALL[].
  SELECT * INTO TABLE LEND_MAIN FROM ZLEND_MAIN WHERE LEND_DEPART
   IN DEPART AND LEND_NO IN NO AND LEND_DATE IN L_DATE AND
   RETURN_DATE IN R_DATE AND (ITAB).
  LOOP AT LEND_MAIN.
    CLEAR INFOR_ALL.
    INFOR_ALL-LEND_NO     = LEND_MAIN-LEND_NO.
    INFOR_ALL-LEND_DEPART = LEND_MAIN-LEND_DEPART.
    CLEAR INFOR_ALL-LEND_DEP.
    SELECT BRTXT INTO INFOR_ALL-LEND_DEP FROM ZT016T WHERE BRSCH =
 INFOR_ALL-LEND_DEPART AND SPRAS = ‘1‘ .
    ENDSELECT.
    INFOR_ALL-DEP_DETAIL  = LEND_MAIN-DEP_DETAIL.
    INFOR_ALL-LEND_DATE   = LEND_MAIN-LEND_DATE.
    INFOR_ALL-RETURN_DATE = LEND_MAIN-RETURN_DATE.
*   infor_all-purpose     = lend_main-purpose.
    CASE LEND_MAIN-PURPOSE.
      WHEN ‘1‘.
        INFOR_ALL-PURPOSE = ‘项目测试‘.
      WHEN ‘2‘.
        INFOR_ALL-PURPOSE = ‘项目备机‘.
      WHEN ‘3‘.
        INFOR_ALL-PURPOSE = ‘缺货使用‘.
      WHEN ‘4‘.
        INFOR_ALL-PURPOSE = ‘开发测试‘.
      WHEN ‘5‘.
        INFOR_ALL-PURPOSE = ‘例行试验‘.
      WHEN ‘6‘.
        INFOR_ALL-PURPOSE = ‘新品测试‘.
      WHEN ‘7‘.
        INFOR_ALL-PURPOSE = ‘各类认证‘.
      WHEN ‘8‘.
        INFOR_ALL-PURPOSE = ‘媒体评测‘.
      WHEN ‘9‘.
        INFOR_ALL-PURPOSE = ‘办公暂借‘.
      WHEN ‘10‘.
        INFOR_ALL-PURPOSE = ‘销售‘.
      WHEN ‘11‘.
        INFOR_ALL-PURPOSE = ‘展览‘.
      WHEN ‘12‘.
        INFOR_ALL-PURPOSE = ‘更换‘.
      WHEN ‘13‘.
        INFOR_ALL-PURPOSE = ‘培训‘.
      WHEN ‘14‘.
        INFOR_ALL-PURPOSE = ‘DOA‘.
    ENDCASE.
    INFOR_ALL-PUR_DETAIL  = LEND_MAIN-PUR_DETAIL.
    INFOR_ALL-MANAGER1    = LEND_MAIN-MANAGER1.
    INFOR_ALL-LENDER      = LEND_MAIN-LENDER.
    INFOR_ALL-OPERATOR    = LEND_MAIN-OPERATOR.
*   infor_all-over_day = sy-datum - lend_main-return_date.

    SELECT * INTO TABLE LEND_DETAIL FROM ZLEND_DETAIL WHERE
    LEND_NO = LEND_MAIN-LEND_NO .
    LOOP AT LEND_DETAIL .
      "加入if 判断已还物信息
      IF LEND_DETAIL-GET_NUM <> LEND_DETAIL-RETURN_NUM.
        INFOR_ALL-MATNR = LEND_DETAIL-MATNR.
        INFOR_ALL-MAKTX = LEND_DETAIL-MAKTX.
        INFOR_ALL-ZTBS  = LEND_DETAIL-ZTBS.
*     infor_all-store_type = lend_detail-store_type.
        CASE LEND_DETAIL-STORE_TYPE.
          WHEN ‘1‘.
            INFOR_ALL-STORE_TYPE = ‘SER整机库‘.
          WHEN ‘2‘.
            INFOR_ALL-STORE_TYPE = ‘SER散件库‘.
          WHEN ‘3‘.
            INFOR_ALL-STORE_TYPE = ‘PC整机库‘.
          WHEN ‘4‘.
            INFOR_ALL-STORE_TYPE = ‘PC散件库‘.
          WHEN ‘5‘.
            INFOR_ALL-STORE_TYPE = ‘PC显示器‘.
          WHEN ‘6‘.
            INFOR_ALL-STORE_TYPE = ‘SER显示器‘.
        ENDCASE.

        CASE LEND_DETAIL-PROPERTY.
          WHEN ‘1‘.
            INFOR_ALL-PROPERTY = ‘A‘.
          WHEN ‘2‘.
            INFOR_ALL-PROPERTY = ‘C‘.
          WHEN ‘3‘.
            INFOR_ALL-PROPERTY = ‘D‘.
          WHEN ‘4‘.
            INFOR_ALL-PROPERTY = ‘B‘.
          WHEN ‘5‘.
            INFOR_ALL-PROPERTY = ‘E‘.
          WHEN ‘6‘.
            INFOR_ALL-PROPERTY = ‘过保‘.
        ENDCASE.
        CASE LEND_DETAIL-STATUS.
          WHEN ‘1‘.
            INFOR_ALL-STATUS = ‘未发货‘.
          WHEN ‘2‘.
            INFOR_ALL-STATUS = ‘部分发货‘.
          WHEN ‘3‘.
            INFOR_ALL-STATUS = ‘全部发货‘.
        ENDCASE.
        INFOR_ALL-APPLY_NUM = LEND_DETAIL-APPLY_NUM.
        INFOR_ALL-GET_NUM   = LEND_DETAIL-GET_NUM.
        INFOR_ALL-RETURN_NUM = LEND_DETAIL-RETURN_NUM.
        INFOR_ALL-OVER_DAY = SY-DATUM - LEND_DETAIL-LAST_DATE.
        INFOR_ALL-LAST_DATE = LEND_DETAIL-LAST_DATE.
        INFOR_ALL-NUM   = INFOR_ALL-GET_NUM - INFOR_ALL-RETURN_NUM .
        INFOR_ALL-APPLY_NO  = LEND_DETAIL-APPLY_NO.
        INFOR_ALL-MEINS     = LEND_DETAIL-MEINS.
        INFOR_ALL-PRICE     = LEND_DETAIL-PRICE.
        INFOR_ALL-TOTAL     = INFOR_ALL-PRICE * INFOR_ALL-APPLY_NUM .
        INFOR_ALL-SENDER    = LEND_DETAIL-SENDER.
        INFOR_ALL-STORER    = LEND_DETAIL-SOTRER.
        INFOR_ALL-MACHI_SERIES = LEND_DETAIL-MACHI_SERIES.
        APPEND INFOR_ALL.
        CLEAR LEND_DETAIL.
      ENDIF.
    ENDLOOP.
  ENDLOOP.
  SORT INFOR_ALL BY PURPOSE.
  CLEAR FIELDCAT[].
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME     = ‘LEND_NO‘.
  FIELDCAT-TABNAME       = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S     = ‘借料单号‘.
  FIELDCAT-SELTEXT_M     = ‘借料单号‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME   = ‘LEND_DEPART‘.
  FIELDCAT-TABNAME     = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S   = ‘部门编号‘.
  FIELDCAT-SELTEXT_M   = ‘部门编号‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME   = ‘LEND_DEP‘.
  FIELDCAT-TABNAME     = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S   = ‘借料部门‘.
  FIELDCAT-SELTEXT_M   = ‘借料部门‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME   = ‘DEP_DETAIL‘.
  FIELDCAT-TABNAME     = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S   = ‘部门详述‘.
  FIELDCAT-SELTEXT_M   = ‘部门详述‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME   = ‘ZTBS‘.
  FIELDCAT-TABNAME     = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S   = ‘在途数量‘.
  FIELDCAT-SELTEXT_M   = ‘在途数量‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME  = ‘LEND_DATE‘.
  FIELDCAT-TABNAME    = ‘LEND_MAIN‘.
  FIELDCAT-SELTEXT_S  = ‘借料日期‘.
  FIELDCAT-SELTEXT_M  = ‘借料日期‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘RETURN_DATE‘.
  FIELDCAT-TABNAME   = ‘LEND_MAIN‘.
  FIELDCAT-SELTEXT_S = ‘预计归还日期‘.
  FIELDCAT-SELTEXT_M = ‘预计归还日期‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘LAST_DATE‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘续借日期‘.
  FIELDCAT-SELTEXT_M = ‘续借日期‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘STATUS‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘发货状态‘.
  FIELDCAT-SELTEXT_M = ‘发货状态‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘PURPOSE‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘用途‘.
  FIELDCAT-SELTEXT_M = ‘用途‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘PUR_DETAIL‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘用途详细‘.
  FIELDCAT-SELTEXT_M = ‘用途详细‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MANAGER1‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘审批经理‘.
  FIELDCAT-SELTEXT_M = ‘审批经理‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘OPERATOR‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘操作人‘.
  FIELDCAT-SELTEXT_M = ‘操作人‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MATNR‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘物料号‘.
  FIELDCAT-SELTEXT_M = ‘物料号‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MAKTX‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘物料描述‘.
  FIELDCAT-SELTEXT_M = ‘物料描述‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MEINS‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘单位‘.
  FIELDCAT-SELTEXT_M = ‘单位‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘STORE_TYPE‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘库类别‘.
  FIELDCAT-SELTEXT_M = ‘库类别‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘PROPERTY‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘物料属性‘.
  FIELDCAT-SELTEXT_M = ‘物料属性‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘APPLY_NUM‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘申请数量‘.
  FIELDCAT-SELTEXT_M = ‘申请数量‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘GET_NUM‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘发货数量‘.
  FIELDCAT-SELTEXT_M = ‘发货数量‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘RETURN_NUM‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘归还数量‘.
  FIELDCAT-SELTEXT_M = ‘归还数量‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘NUM‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘余额‘.
  FIELDCAT-SELTEXT_M = ‘余额‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘LENDER‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘借物人‘.
  FIELDCAT-SELTEXT_M = ‘借物人‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘PRICE‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘单价‘.
  FIELDCAT-SELTEXT_M = ‘单价‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘TOTAL‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘金额‘.
  FIELDCAT-SELTEXT_M = ‘金额‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘APPLY_NO‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘申请单号‘.
  FIELDCAT-SELTEXT_M = ‘申请单号‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MACHI_SERIES‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘机器序列号‘.
  FIELDCAT-SELTEXT_M = ‘机器序列号‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘OVER_DAY‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘超期天数‘.
  FIELDCAT-SELTEXT_M = ‘超期天数‘.
  APPEND FIELDCAT.


  CALL FUNCTION ‘REUSE_ALV_GRID_DISPLAY‘
    EXPORTING
      IT_FIELDCAT = FIELDCAT[]
      I_DEFAULT   = ‘X‘
      I_SAVE      = ‘A‘
    TABLES
      T_OUTTAB    = INFOR_ALL
    EXCEPTIONS
      OTHERS      = 2.
ENDFORM.                    "LEND_DATA
*&--------------------------------------------------------------------*
*&      Form  RETU_dat
*&--------------------------------------------------------------------*
*       text
*---------------------------------------------------------------------*
FORM RETU_DAT."单据打印
  IF  C_LEND = ‘X‘."借料单打印
    PERFORM PRINT_LEND.
  ENDIF.
  IF C_RETU = ‘X‘.
    PERFORM PRINT_RETURN."还料单打印
  ENDIF.
  IF C_LLD = ‘X‘."领料单打印
    PERFORM PRINT_LLD.
  ENDIF.

ENDFORM.                    "RETU_dat
*&--------------------------------------------------------------------*
*&      Form  print_lend
*&--------------------------------------------------------------------*
*       text
*---------------------------------------------------------------------*
FORM PRINT_LEND."
  CLEAR LEND_MAIN[]."借物单据打印
  CLEAR LEND_DETAIL[].
  CLEAR NUM3 .
  NUM2 = 0 .
  NUM = 1 .
  SELECT * INTO TABLE LEND_MAIN FROM ZLEND_MAIN WHERE LEND_DEPART IN
DEPART AND LEND_NO IN NO AND LEND_DATE IN L_DATE AND RETURN_DATE IN
R_DATE AND (ITAB).
  LOOP AT LEND_MAIN.
    SELECT * INTO TABLE LEND_DETAIL FROM ZLEND_DETAIL WHERE LEND_NO =
    LEND_MAIN-LEND_NO.
    NUM3 = SY-DBCNT.
    LOOP AT LEND_DETAIL."查找所有的发货数量不等于申请数量的数据
      IF LEND_DETAIL-APPLY_NUM > LEND_DETAIL-GET_NUM.
        IF NUM2 = 0 .
          WRITE / .
          WRITE / .
          WRITE /  .

          WRITE 30 ‘浪潮信息公司借物单‘.
          WRITE : 60  ‘单号:‘ , LEND_MAIN-LEND_NO.
*         write 58 num."用于输出单子树木

          WRITE /26(30) SY-ULINE .
          CLEAR INFOR_ALL-LEND_DEP.
          SELECT BRTXT INTO INFOR_ALL-LEND_DEP FROM ZT016T WHERE BRSCH =
 LEND_MAIN-LEND_DEPART AND SPRAS = ‘1‘ .
          ENDSELECT.

*         write :  /2 ‘借料部门:‘ , lend_main-lend_depart.
          WRITE :  /2 ‘借料部门:‘ , INFOR_ALL-LEND_DEP.
          WRITE :  ‘借料日期:‘ , LEND_MAIN-LEND_DATE.
          WRITE :  ‘应还日期:‘ , LEND_MAIN-RETURN_DATE.
*         write :  ‘单号:‘ , lend_main-lend_no.

          WRITE /0(80) SY-ULINE.
          WRITE /0 SY-VLINE.
          WRITE 80 SY-VLINE.
          WRITE : 5 ‘产品编码‘.
          WRITE  19 SY-VLINE.
          WRITE :  30 ‘物料描述 ‘ .
*         write 59 sy-vline.
*         write :  60 ‘SN/QN‘ .
*         write :  60 ‘单位‘ .
          WRITE 64 SY-VLINE.
          WRITE :  65 ‘单位‘.
          WRITE  80 SY-VLINE.
          WRITE 69 SY-VLINE.
          WRITE :  74 ‘数量‘.
          WRITE : /0(80) SY-ULINE.
        ENDIF.
        NUM2 = NUM2 + 1 .
        "add lend_detial infromation
        WRITE /0 SY-VLINE.
        WRITE : LEND_DETAIL-MATNR.
        WRITE 19 SY-VLINE.
        WRITE : 20 LEND_DETAIL-MAKTX.
*       write 59 sy-vline.


*       write : 74 lend_detail-apply_num .
*       write 64 lend_detail-apply_num .
        CLEAR S.
        S = LEND_DETAIL-APPLY_NUM.
        WRITE 71(10) S .
        WRITE 64 SY-VLINE.
        WRITE : 65 LEND_DETAIL-MEINS.
        WRITE SY-VLINE.
        WRITE 80 SY-VLINE.
        WRITE /0(80) SY-ULINE.

        WRITE /0 SY-VLINE.
        WRITE 2 ‘SN/QN‘.
        WRITE 19 SY-VLINE.
        WRITE 80 SY-VLINE.
        WRITE /0(80) SY-ULINE.

        CASE LEND_DETAIL-STORE_TYPE.
          WHEN ‘1‘.
            S_STORE = ‘SER整机库‘.
          WHEN ‘2‘.
            S_STORE = ‘SER散件库‘.
          WHEN ‘3‘.
            S_STORE = ‘PC整机库‘.
          WHEN ‘4‘.
            S_STORE = ‘PC散件库‘.
          WHEN ‘5‘.
            S_STORE = ‘PC显示器‘.
          WHEN ‘6‘.
            S_STORE = ‘SER显示器‘.
          WHEN ‘7‘.
            S_STORE = ‘存储整机‘.
          WHEN ‘8‘.
            S_STORE = ‘存储散件‘.
          WHEN ‘9‘.
            S_STORE = ‘高性能整机‘.
          WHEN ‘10‘.
            S_STORE = ‘高性能散件‘.
          WHEN ‘11‘.
            S_STORE = ‘VIT整机‘.
          WHEN ‘12‘.
            S_STORE = ‘VIT散件‘.
          WHEN ‘13‘.
            S_STORE = ‘高端整机‘.
          WHEN ‘14‘.
            S_STORE = ‘高端散件‘.
        ENDCASE.
        CASE LEND_DETAIL-PROPERTY.
          WHEN ‘1‘.
            P_PRO = ‘A‘.
          WHEN ‘2‘.
            P_PRO = ‘C‘.
          WHEN ‘3‘.
            P_PRO = ‘D‘.
          WHEN ‘4‘.
            P_PRO = ‘B‘.
          WHEN ‘5‘.
            P_PRO = ‘E‘.
          WHEN ‘6‘.
            P_PRO = ‘过保‘.
          WHEN ‘7‘.
            P_PRO = ‘C1‘.
        ENDCASE.
*       if num2 = sy-dbcnt ."打印完详细
        IF NUM2 = NUM3 ."打印完详细
          WRITE /0 SY-VLINE .
          WRITE 2 ‘用途说明:‘.
          WRITE LEND_MAIN-PUR_DETAIL.
          WRITE 59 SY-VLINE.
          WRITE 80 SY-VLINE.
          WRITE /0 SY-VLINE.
          WRITE 59 SY-VLINE.
          WRITE 80 SY-VLINE.

          WRITE /0 SY-VLINE.
          WRITE  ‘备注:‘.
          WRITE 59 SY-VLINE.
          WRITE 80 SY-VLINE .
**********************************add by dingyang 091217**********************************
*          使输出字段拐弯,判断最后一个字符是否正常显示
          DATA : B1(55),B2(55TYPE C.
          IF STRLEN( LEND_MAIN-BZ ) > 56.
            CLEAR B1.
            CLEAR B2.
            PERFORM WRITE_STRING USING LEND_MAIN-BZ B1 B2 .
            WRITE /0 SY-VLINE .
            WRITE B1.
            WRITE 59 SY-VLINE.
            WRITE 80 SY-VLINE .
            WRITE /0 SY-VLINE.
            WRITE B2.
            WRITE 59 SY-VLINE.
            WRITE 80 SY-VLINE .
          ELSE.
            WRITE LEND_MAIN-BZ.
            WRITE 59 SY-VLINE.
            WRITE 80 SY-VLINE .
          ENDIF.

**********************************end by dingyang 091217**********************************


          WRITE 60 ‘库别:‘.
          WRITE S_STORE.
          WRITE 80 SY-VLINE .

          WRITE /0 SY-VLINE.
*         WRITE ‘打印人:‘.
*         WRITE SY-UNAME.
*         WRITE ‘提货人:‘.
          WRITE 80 SY-VLINE.
          WRITE 59 SY-VLINE.
*         write  60 ‘属性:‘ .
*         write p_pro.
          WRITE /0 SY-VLINE.
          WRITE ‘打印人:‘.
          WRITE SY-UNAME.
          WRITE ‘提货人:‘.
          WRITE 59 SY-VLINE.
          WRITE  60 ‘属性:‘ .
          WRITE P_PRO.
          WRITE 80 SY-VLINE.
          WRITE /0(80) SY-ULINE .

          "add other information
          WRITE : /2 ‘批准人:‘ .
          IF ( LEND_MAIN-LEND_DEPART = ‘2600‘ AND ( LEND_MAIN-OPERATOR <>
          ‘GUOYH‘ OR LEND_MAIN-OPERATOR <> ‘LIUYL‘) ).
*           if lend_detail-property <> ‘1‘.
*             write lend_main-manager1.
*           endif. 注释与2005.12.26
          ELSEIF ( LEND_MAIN-LEND_DEPART = ‘2600‘ AND (
          LEND_MAIN-OPERATOR <>
          ‘GUOYH‘ OR LEND_MAIN-OPERATOR <> ‘LIUYL‘ ) ).
*             WRITE LEND_MAIN-MANAGER1 .
          ELSE.
            WRITE LEND_MAIN-MANAGER1.
          ENDIF.
          WRITE : 22 ‘保管员:‘, LEND_MAIN-STORER.
          WRITE : 37 ‘制单人:‘, LEND_MAIN-OPERATOR.
          WRITE  : 55 ‘借料人:‘ , LEND_MAIN-LENDER.
          WRITE / .
          WRITE / .
*         num2 = 1 .
        ENDIF.                                              "num2 end
      ENDIF.
    ENDLOOP.

*     num = num + 1 .
    NEW-PAGE.
    NUM2 = 0 .
  ENDLOOP.

ENDFORM.                    "print_lend
*&--------------------------------------------------------------------*
*&      Form  print_return
*&--------------------------------------------------------------------*
*       text
*---------------------------------------------------------------------*
FORM PRINT_RETURN."还物单打印
  NUM2 = 0 .
  CLEAR RETURN_DATA[].
  CLEAR RETURN_DAT[]."存储临时数据用于检索
  CLEAR RETURN_DAT.
  CLEAR NUM3.
  SELECT DISTINCT RETURN_NO   INTO CORRESPONDING FIELDS OF
  RETURN_DAT FROM ZRETURN_INFOR
  WHERE MANAGER2 <> ‘1‘ AND RETURN_DEPART IN DEPART AND
  LEND_NO IN NO AND RETURN_NO IN R_NO AND (ITAB).
    APPEND RETURN_DAT.
  ENDSELECT.
  LOOP AT RETURN_DAT.
    SELECT * INTO TABLE RETURN_DATA FROM ZRETURN_INFOR WHERE RETURN_NO =
     RETURN_DAT-RETURN_NO .
    NUM3 = SY-DBCNT.
    LOOP AT RETURN_DATA .

      IF NUM2 = 0 .
        WRITE / .
        WRITE / .
        WRITE 30 ‘还    料    单‘.
        WRITE 58 NUM.

        WRITE /26(30) SY-ULINE .
        CLEAR INFOR_ALL-LEND_DEP.
        SELECT BRTXT INTO INFOR_ALL-LEND_DEP FROM ZT016T WHERE BRSCH =
  RETURN_DATA-RETURN_DEPART AND SPRAS = ‘1‘.
        ENDSELECT.


*************************ADD  BY DINGYANG 091210*************************
*     增加原物料属性
        CLEAR P_PRY.
        SELECT  SINGLE PROPERTY INTO P_PRY FROM ZLEND_DETAIL WHERE LEND_NO = RETURN_DATA-LEND_NO AND MATNR = RETURN_DATA-MATNR.

        CASE P_PRY.
          WHEN ‘1‘.
            P_PRY = ‘A‘.
          WHEN ‘2‘.
            P_PRY = ‘C‘.
          WHEN ‘3‘.
            P_PRY = ‘D‘.
          WHEN ‘4‘.
            P_PRY = ‘B‘.
          WHEN ‘5‘.
            P_PRY = ‘E‘.
          WHEN ‘6‘.
            P_PRY = ‘过保‘.
          WHEN ‘7‘.
            P_PRY = ‘C1‘.
        ENDCASE.

*************************END  BY DINGYANG 091210*************************




*      write :  /2 ‘还料部门:‘ , return_data-return_depart.
        WRITE :  /2 ‘还料部门:‘ , INFOR_ALL-LEND_DEP.
        WRITE :  ‘ 日 期 :‘ , SY-DATUM.
        WRITE : 58 ‘还料单号:‘.
        "以下原有是还料单流水号码的生成
*           PERFORM GET_HLD_NO.
*           CONCATENATE ‘H‘ HLD_NO INTO HLD_NO.
*           WRITE HLD_NO .
        "流水号码生成结束

        WRITE RETURN_DATA-RETURN_NO .

        "将zreturn_infor的manager2更改为 1 --〉已经打印过

        WRITE /0(84) SY-ULINE.
        WRITE /0 SY-VLINE.
        WRITE 84 SY-VLINE.
        WRITE : 5 ‘产品编码‘.
        WRITE : 19 SY-VLINE.
        WRITE :  30 ‘物料描述 ‘ .
        WRITE 59 SY-VLINE.
        WRITE :  63 ‘数量‘.
        WRITE   70 SY-VLINE.
        WRITE :  72 ‘借料单号‘.
        WRITE   SY-VLINE.
        WRITE :  82 ‘原‘.
      ENDIF.                                                " num2 end
      NUM2 = NUM2 + 1 .
      "and lend_detail information
      WRITE : /0(84) SY-ULINE.
      WRITE /0 SY-VLINE.
      WRITE : RETURN_DATA-MATNR.
      WRITE 19 SY-VLINE.
      WRITE : 20 RETURN_DATA-MAKTX.
*     write 77 sy-vline.return_num 为13位显示不开

*     write 63 sy-vline.
*     write : 57 return_data-return_num .
      CLEAR S.
      S = RETURN_DATA-RETURN_NUM.
      WRITE : 61(9) S .
      WRITE 59 SY-VLINE."那到这儿显示

      WRITE 70 SY-VLINE.
      WRITE : 71 RETURN_DATA-LEND_NO .
      WRITE 81 SY-VLINE.
      WRITE : 83 P_PRY .

      WRITE 84 SY-VLINE.

      WRITE /0(84)  SY-ULINE.
      WRITE /0 SY-VLINE.
      WRITE  ‘SN/QN : ‘ .
      WRITE RETURN_DATA-MACHI_SERIES.
      WRITE 84 SY-VLINE.



*     write /0 sy-uline.
      CASE RETURN_DATA-STORE_TYPE.
        WHEN ‘1‘.
          S_STORE = ‘SER整机库‘.
        WHEN ‘2‘.
          S_STORE = ‘SER散件库‘.
        WHEN ‘3‘.
          S_STORE = ‘PC整机库‘.
        WHEN ‘4‘.
          S_STORE = ‘PC散件库‘.
        WHEN ‘5‘.
          S_STORE = ‘PC显示器‘.
        WHEN ‘6‘.
          S_STORE = ‘SER显示器‘.
        WHEN ‘7‘.
          S_STORE = ‘存储整机‘.
        WHEN ‘8‘.
          S_STORE = ‘存储散件‘.
        WHEN ‘9‘.
          S_STORE = ‘高性能整机‘.
        WHEN ‘10‘.
          S_STORE = ‘高性能散件‘.
        WHEN ‘11‘.
          S_STORE = ‘VIT整机‘.
        WHEN ‘12‘.
          S_STORE = ‘VIT散件‘.
        WHEN ‘13‘.
          S_STORE = ‘高端整机‘.
        WHEN ‘14‘.
          S_STORE = ‘高端散件‘.

      ENDCASE.
      CASE RETURN_DATA-PROPERTY.
        WHEN ‘1‘.
          P_PRO = ‘A‘.
        WHEN ‘2‘.
          P_PRO = ‘C‘.
        WHEN ‘3‘.
          P_PRO = ‘D‘.
        WHEN ‘4‘.
          P_PRO = ‘B‘.
        WHEN ‘5‘.
          P_PRO = ‘E‘.
        WHEN ‘6‘.
          P_PRO = ‘过保‘.
        WHEN ‘7‘.
          P_PRO = ‘C1‘.
      ENDCASE.
      IF NUM2 = NUM3 .
        WRITE /0(84) SY-ULINE.
        WRITE /0 SY-VLINE .
        WRITE 2 ‘检验结果:‘.
        WRITE 53 SY-VLINE.
        WRITE 54 ‘库别:‘.
        WRITE S_STORE.
        WRITE 84 SY-VLINE .
*************************ADD  BY DINGYANG 091210*************************
*        WRITE /0 SY-VLINE.
*        WRITE 53 SY-VLINE.
*        WRITE 54 ‘原借物属性:‘ .
*        WRITE P_PRY.
*    WRITE 80 SY-VLINE .
*************************END  BY DINGYANG 091210*************************

        WRITE /0 SY-VLINE.
        WRITE 84 SY-VLINE.




        WRITE 53 SY-VLINE.
        WRITE  54 ‘属性:‘ .
        WRITE P_PRO.
        WRITE /0(84) SY-ULINE .

        WRITE /0 SY-VLINE.
        WRITE 2 ‘备注:‘.
        WRITE 10 RETURN_DATA-DETAIL.
        WRITE : 40 ‘打印人:‘.
        WRITE SY-UNAME.
        WRITE ‘提货人:‘.
        WRITE 84 SY-VLINE.
        WRITE /0(84) SY-ULINE.
        "add other information
        WRITE : /4 ‘批准人:‘ .
        IF RETURN_DATA-RETURN_DEPART = ‘2600‘.

        ELSE.
          WRITE RETURN_DATA-MANAGER1.
        ENDIF.
        WRITE : 25 ‘保管员:‘, RETURN_DATA-STORER.
        WRITE : 38 ‘制单人:‘, RETURN_DATA-OPERATOR.
        WRITE  : 55 ‘借料人:‘ , RETURN_DATA-RETURNER.
        WRITE / .
        WRITE / .
        NUM2 = 0 .
        NEW-PAGE.
      ENDIF."num2 = sy-dbcnt end
    ENDLOOP.
  ENDLOOP.
ENDFORM.                    "print_return
*&--------------------------------------------------------------------*
*&      Form  print_lld
*&--------------------------------------------------------------------*
*       text
*---------------------------------------------------------------------*
FORM PRINT_LLD."领料单打印
  CLEAR NUM2 .
  NUM3 = 1 .
  CLEAR LEND_LL[].
  CLEAR LEND_LL.
  SELECT * INTO TABLE LEND_LL FROM ZLEND_LL WHERE
 DEP_NO IN DEPART AND TYP = ‘+‘
  AND LEND_NO IN NO AND RETURN_NO IN R_NO  AND (ITAB).
  LOOP AT LEND_LL.
    IF  NUM3 = 1 .
      NUM3 = NUM3 + 1 .
      SELECT COUNT(*) INTO NUM2 FROM ZLEND_LL WHERE
    LING_NO = LEND_LL-LING_NO .
      NUM2 = NUM2 + 1 .
      WRITE / .
      WRITE / .
      WRITE 30 ‘借还物调帐专用领料单 ‘.
      WRITE /26(30) SY-ULINE.
      WRITE / .
      WRITE / .

      CLEAR INFOR_ALL-LEND_DEP.
      SELECT BRTXT INTO INFOR_ALL-LEND_DEP FROM ZT016T WHERE BRSCH =
 LEND_LL-DEP_NO AND SPRAS = ‘1‘.
      ENDSELECT.
      WRITE : /2 ‘领料部门:‘ , INFOR_ALL-LEND_DEP.
      WRITE : ‘日期 : ‘.
      WRITE SY-DATUM.
      WRITE 54 ‘领料单号:‘.
      WRITE LEND_LL-LING_NO.

      WRITE /0(80) SY-ULINE.
      WRITE /0 SY-VLINE.
      WRITE 80 SY-VLINE.
      WRITE : 5 ‘产品编码‘.
      WRITE : 19 SY-VLINE.
      WRITE : 30 ‘物料描述‘.
      WRITE : 63 SY-VLINE.
      WRITE : 64 ‘单位‘.
      WRITE : 68 SY-VLINE.
      WRITE : 74 ‘数量‘.
      WRITE 80 SY-VLINE.

      WRITE 0(80) SY-ULINE.
      WRITE /0 SY-VLINE.
      WRITE LEND_LL-MATNR.
      WRITE : 19 SY-VLINE.
      WRITE LEND_LL-MAKTX.
      WRITE  63 SY-VLINE.
      CLEAR S.
      S = LEND_LL-RETURN_NUM.
      WRITE : 70 S.
      WRITE : 68 SY-VLINE.
      WRITE LEND_LL-TYP.
      WRITE 64 LEND_LL-MEINS.

      WRITE 80 SY-VLINE.

      WRITE 0(80) SY-ULINE.
      WRITE /0 SY-VLINE .
      WRITE  ‘SN/QN : ‘.
      WRITE LEND_LL-MACHI_SERIES.
      WRITE 80 SY-VLINE .
    ELSEIF NUM3 > 1  .
      NUM3 = NUM3 + 1.
      WRITE 0(80) SY-ULINE.
      WRITE /0 SY-VLINE.
      WRITE LEND_LL-MATNR.
      WRITE : 19 SY-VLINE.
      WRITE LEND_LL-MAKTX.
      WRITE  63 SY-VLINE.
      CLEAR S2.
      S2 = LEND_LL-RETURN_NUM.
      WRITE : 70 S2.
      WRITE 64 LEND_LL-MEINS.
      WRITE : 68 SY-VLINE.
      WRITE  LEND_LL-TYP.

      WRITE 80 SY-VLINE.

      WRITE 0(80) SY-ULINE.
      WRITE /0 SY-VLINE .
      WRITE  ‘SN/QN : ‘.
      WRITE LEND_LL-MACHI_SERIES.
      WRITE 80 SY-VLINE .
    ENDIF.
    IF  NUM3 =  NUM2 .
      NUM3 = 1 .
      CLEAR NUM2 .
      WRITE 0(80) SY-ULINE.
      WRITE /0 SY-VLINE.
      WRITE ‘用途说明‘.
*        write sy-vline.
      WRITE 54 SY-VLINE.
      WRITE 55 ‘库 类 别:‘.
      CASE LEND_LL-STORE.
        WHEN ‘1‘.
          S_STORE = ‘SER整机库‘.
        WHEN ‘2‘.
          S_STORE = ‘SER散件库‘.
        WHEN ‘3‘.
          S_STORE = ‘PC整机库‘.
        WHEN ‘4‘.
          S_STORE = ‘PC散件库‘.
        WHEN ‘5‘.
          S_STORE = ‘PC显示器‘.
        WHEN ‘6‘.
          S_STORE = ‘SER显示器‘.
        WHEN ‘7‘.
          S_STORE = ‘存储整机‘.
        WHEN ‘8‘.
          S_STORE = ‘存储散件‘.
        WHEN ‘9‘.
          S_STORE = ‘高性能整机‘.
        WHEN ‘10‘.
          S_STORE = ‘高性能散件‘.
        WHEN ‘11‘.
          S_STORE = ‘VIT整机‘.
        WHEN ‘12‘.
          S_STORE = ‘VIT散件‘.
        WHEN ‘13‘.
          S_STORE = ‘高端整机‘.
        WHEN ‘14‘.
          S_STORE = ‘高端散件‘.

      ENDCASE.

      WRITE S_STORE .
      WRITE 80 SY-VLINE.
      WRITE /0 SY-VLINE.
*        write 12 sy-vline.
      WRITE ‘打印人:‘.
      WRITE SY-UNAME.
      WRITE ‘提货人:‘.
      WRITE 54 SY-VLINE.
      WRITE 55 ‘物料属性:‘.
      CLEAR P_PRO .
      CASE LEND_LL-PROPERTY.
        WHEN ‘1‘.
          P_PRO = ‘A‘.
        WHEN ‘2‘.
          P_PRO = ‘C‘.
        WHEN ‘3‘.
          P_PRO = ‘D‘.
        WHEN ‘4‘.
          P_PRO = ‘B‘.
        WHEN ‘5‘.
          P_PRO = ‘E‘.
        WHEN ‘6‘.
          P_PRO = ‘过保‘.
        WHEN ‘7‘.
          P_PRO = ‘C1‘.
      ENDCASE.
      WRITE P_PRO .
      WRITE 80 SY-VLINE.
      WRITE /0(80) SY-ULINE.

      WRITE /3 ‘批准人‘.
      IF LEND_LL-DEP_NO <> ‘2000‘.
*          write return_data-manager1.
        WRITE LEND_LL-MANAGER1.
      ENDIF.
      WRITE 25 ‘保管员:‘.
*        write return_data-storer.
      WRITE 38 ‘制单人:‘.
      WRITE LEND_LL-OPERATOR.
      WRITE 55 ‘领料人:‘.
      WRITE LEND_LL-RETURNER.
      WRITE /.
      WRITE /.
      NEW-PAGE.
    ENDIF.
  ENDLOOP.

*  打印负领料单
  CLEAR NUM2 .
  NUM3 = 1 .
  CLEAR LEND_LL[].
  CLEAR LEND_LL.
  SELECT * INTO TABLE LEND_LL FROM ZLEND_LL WHERE
 DEP_NO IN DEPART AND TYP = ‘-‘
  AND LEND_NO IN NO AND RETURN_NO IN R_NO  AND (ITAB).
  LOOP AT LEND_LL.
    IF  NUM3 = 1 .
      NUM3 = NUM3 + 1 .
      SELECT COUNT(*) INTO NUM2 FROM ZLEND_LL WHERE
    LING_NO = LEND_LL-LING_NO .
      NUM2 = NUM2 + 1 .
      WRITE / .
      WRITE / .
      WRITE 30 ‘借还物调帐专用领料单 ‘.
      WRITE /26(30) SY-ULINE.
      WRITE / .
      WRITE / .

      CLEAR INFOR_ALL-LEND_DEP.
      SELECT BRTXT INTO INFOR_ALL-LEND_DEP FROM ZT016T WHERE BRSCH =
 LEND_LL-DEP_NO AND SPRAS = ‘1‘.
      ENDSELECT.
      WRITE : /2 ‘领料部门:‘ , INFOR_ALL-LEND_DEP.
      WRITE : ‘日期 : ‘.
      WRITE SY-DATUM.
      WRITE 54 ‘领料单号:‘.
      WRITE LEND_LL-LING_NO.

      WRITE /0(80) SY-ULINE.
      WRITE /0 SY-VLINE.
      WRITE 80 SY-VLINE.
      WRITE : 5 ‘产品编码‘.
      WRITE : 19 SY-VLINE.
      WRITE : 30 ‘物料描述‘.
      WRITE : 63 SY-VLINE.
      WRITE : 64 ‘单位‘.
      WRITE : 68 SY-VLINE.
      WRITE : 74 ‘数量‘.
      WRITE 80 SY-VLINE.

      WRITE 0(80) SY-ULINE.
      WRITE /0 SY-VLINE.
      WRITE LEND_LL-MATNR.
      WRITE : 19 SY-VLINE.
      WRITE LEND_LL-MAKTX.
      WRITE  63 SY-VLINE.
      CLEAR S.
      S = LEND_LL-RETURN_NUM.
      WRITE : 70 S.
      WRITE : 68 SY-VLINE.
      WRITE LEND_LL-TYP.
      WRITE 64 LEND_LL-MEINS.

      WRITE 80 SY-VLINE.

      WRITE 0(80) SY-ULINE.
      WRITE /0 SY-VLINE .
      WRITE  ‘SN/QN : ‘.
*        write lend_ll-machi_series.
      WRITE LEND_LL-SERIES .
      WRITE 80 SY-VLINE .
    ELSEIF NUM3 > 1  .
      NUM3 = NUM3 + 1.
      WRITE 0(80) SY-ULINE.
      WRITE /0 SY-VLINE.
      WRITE LEND_LL-MATNR.
      WRITE : 19 SY-VLINE.
      WRITE LEND_LL-MAKTX.
      WRITE  63 SY-VLINE.
      CLEAR S2.
      S2 = LEND_LL-RETURN_NUM.
      WRITE : 70 S2.
      WRITE : 68 SY-VLINE.
      WRITE LEND_LL-TYP.
      WRITE 64 LEND_LL-MEINS.

      WRITE 80 SY-VLINE.

      WRITE 0(80) SY-ULINE.
      WRITE /0 SY-VLINE .
      WRITE  ‘SN/QN : ‘.
      WRITE LEND_LL-MACHI_SERIES.
      WRITE 80 SY-VLINE .
    ENDIF.
    IF  NUM3 =  NUM2 .
      NUM3 = 1 .
      CLEAR NUM2 .
      WRITE 0(80) SY-ULINE.
      WRITE /0 SY-VLINE.
      WRITE ‘用途说明‘.
*        write sy-vline.
      WRITE 54 SY-VLINE.
      WRITE 55 ‘库 类 别:‘.
      CASE LEND_LL-STORE.
        WHEN ‘1‘.
          S_STORE = ‘SER整机库‘.
        WHEN ‘2‘.
          S_STORE = ‘SER散件库‘.
        WHEN ‘3‘.
          S_STORE = ‘PC整机库‘.
        WHEN ‘4‘.
          S_STORE = ‘PC散件库‘.
        WHEN ‘5‘.
          S_STORE = ‘PC显示器‘.
        WHEN ‘6‘.
          S_STORE = ‘SER显示器‘.
        WHEN ‘7‘.
          S_STORE = ‘存储整机‘.
        WHEN ‘8‘.
          S_STORE = ‘存储散件‘.
        WHEN ‘9‘.
          S_STORE = ‘高性能整机‘.
        WHEN ‘10‘.
          S_STORE = ‘高性能散件‘.
        WHEN ‘11‘.
          S_STORE = ‘VIT整机‘.
        WHEN ‘12‘.
          S_STORE = ‘VIT散件‘.
        WHEN ‘13‘.
          S_STORE = ‘高端整机‘.
        WHEN ‘14‘.
          S_STORE = ‘高端散件‘.

      ENDCASE.

      WRITE S_STORE .
      WRITE 80 SY-VLINE.
      WRITE /0 SY-VLINE.
*        write 12 sy-vline.
      WRITE ‘打印人:‘.
      WRITE SY-UNAME.
      WRITE ‘提货人:‘.
      WRITE 54 SY-VLINE.
      WRITE 55 ‘物料属性:‘.
      CLEAR P_PRO .
      CASE LEND_LL-PROPERTY.
        WHEN ‘1‘.
          P_PRO = ‘A‘.
        WHEN ‘2‘.
          P_PRO = ‘C‘.
        WHEN ‘3‘.
          P_PRO = ‘D‘.
        WHEN ‘4‘.
          P_PRO = ‘B‘.
        WHEN ‘5‘.
          P_PRO = ‘E‘.
        WHEN ‘6‘.
          P_PRO = ‘过保‘.
        WHEN ‘7‘.
          P_PRO = ‘C1‘.
      ENDCASE.
      WRITE P_PRO .
      WRITE 80 SY-VLINE.
      WRITE /0(80) SY-ULINE.

      WRITE /3 ‘批准人‘.
      IF LEND_LL-DEP_NO <> ‘2000‘.
*          write return_data-manager1.
        WRITE LEND_LL-MANAGER1.
      ENDIF.
      WRITE 25 ‘保管员:‘.
*        write return_data-storer.
      WRITE 38 ‘制单人:‘.
      WRITE LEND_LL-OPERATOR.
      WRITE 55 ‘领料人:‘.
      WRITE LEND_LL-RETURNER.
      WRITE /.
      WRITE /.
      NEW-PAGE.
    ENDIF.
  ENDLOOP.


ENDFORM.                    "print_lld
*&--------------------------------------------------------------------*
*&      Form  pur_data
*&--------------------------------------------------------------------*
*       text
*---------------------------------------------------------------------*
FORM PUR_DATA."用途分析已还信息
  IF SY-UNAME = ‘YINGZHAO‘ OR SY-UNAME = ‘ZHANGSHP‘ OR SY-UNAME =
‘YAOLJ‘.
    NAME = ‘2000‘.
    IF ITAB IS INITIAL.
      CONCATENATE ‘LEND_DEPART = ‘ ‘ NAME ‘INTO ITAB.
    ELSE.
      CONCATENATE ‘ AND LEND_DEPART = ‘ ‘ NAME ‘INTO ITAB.
    ENDIF.
    APPEND ITAB.
    CLEAR DEPART.
  ENDIF.

  CLEAR LEND_MAIN[].
  CLEAR LEND_DETAIL[].
  CLEAR INFOR_ALL[].
  SELECT * INTO TABLE LEND_MAIN FROM ZLEND_MAIN WHERE
  LEND_DEPART IN DEPART AND LEND_NO IN NO AND RETURN_DATE IN R_NO AND
LEND_DATE IN L_DATE AND (ITAB).
  LOOP AT LEND_MAIN.
    CLEAR INFOR_ALL.
    INFOR_ALL-LEND_NO     = LEND_MAIN-LEND_NO.
    INFOR_ALL-LEND_DEPART = LEND_MAIN-LEND_DEPART.
    CLEAR INFOR_ALL-LEND_DEP .
    SELECT BRTXT INTO INFOR_ALL-LEND_DEP FROM ZT016T WHERE BRSCH =
 INFOR_ALL-LEND_DEPART AND SPRAS = ‘1‘ .
    ENDSELECT.
    INFOR_ALL-DEP_DETAIL  = LEND_MAIN-DEP_DETAIL.
    INFOR_ALL-LEND_DATE   = LEND_MAIN-LEND_DATE.
    INFOR_ALL-RETURN_DATE = LEND_MAIN-RETURN_DATE.
*   infor_all-purpose     = lend_main-purpose.
    CASE LEND_MAIN-PURPOSE.
      WHEN ‘1‘.
        INFOR_ALL-PURPOSE = ‘项目测试‘.
      WHEN ‘2‘.
        INFOR_ALL-PURPOSE = ‘项目备机‘.
      WHEN ‘3‘.
        INFOR_ALL-PURPOSE = ‘缺货使用‘.
      WHEN ‘4‘.
        INFOR_ALL-PURPOSE = ‘开发测试‘.
      WHEN ‘5‘.
        INFOR_ALL-PURPOSE = ‘例行试验‘.
      WHEN ‘6‘.
        INFOR_ALL-PURPOSE = ‘新品测试‘.
      WHEN ‘7‘.
        INFOR_ALL-PURPOSE = ‘各类认证‘.
      WHEN ‘8‘.
        INFOR_ALL-PURPOSE = ‘媒体评测‘.
      WHEN ‘9‘.
        INFOR_ALL-PURPOSE = ‘办公暂借‘.
      WHEN ‘10‘.
        INFOR_ALL-PURPOSE = ‘销售‘.
      WHEN ‘11‘.
        INFOR_ALL-PURPOSE = ‘展览‘.
      WHEN ‘12‘.
        INFOR_ALL-PURPOSE = ‘更换‘.
      WHEN ‘13‘.
        INFOR_ALL-PURPOSE = ‘培训‘.
      WHEN ‘14‘.
        INFOR_ALL-PURPOSE = ‘DOA‘.
    ENDCASE.

    INFOR_ALL-PUR_DETAIL  = LEND_MAIN-PUR_DETAIL.
    INFOR_ALL-MANAGER1    = LEND_MAIN-MANAGER1.
    INFOR_ALL-LENDER      = LEND_MAIN-LENDER.
    INFOR_ALL-OPERATOR    = LEND_MAIN-OPERATOR.

    SELECT * INTO TABLE LEND_DETAIL FROM ZLEND_DETAIL WHERE
    LEND_NO = LEND_MAIN-LEND_NO .
    LOOP AT LEND_DETAIL .
      "加入if 判断已还物信息
      IF LEND_DETAIL-GET_NUM = LEND_DETAIL-RETURN_NUM
      AND LEND_DETAIL-GET_NUM > 0 .
        INFOR_ALL-MATNR = LEND_DETAIL-MATNR.
        INFOR_ALL-MAKTX = LEND_DETAIL-MAKTX.
        "infor_all-ztbs = lend_detail-ztbs .不必有在途标示
*     infor_all-store_type = lend_detail-store_type.
*     infor_all-property = lend_detail-property.
        CASE LEND_DETAIL-STORE_TYPE.
          WHEN ‘1‘.
            INFOR_ALL-STORE_TYPE = ‘SER整机库‘.
          WHEN ‘2‘.
            INFOR_ALL-STORE_TYPE = ‘SER散件库‘.
          WHEN ‘3‘.
            INFOR_ALL-STORE_TYPE = ‘PC整机库‘.
          WHEN ‘4‘.
            INFOR_ALL-STORE_TYPE = ‘PC散件库‘.
          WHEN ‘5‘.
            INFOR_ALL-STORE_TYPE = ‘PC显示器‘.
          WHEN ‘6‘.
            INFOR_ALL-STORE_TYPE = ‘SER显示器‘.
        ENDCASE.

        CASE LEND_DETAIL-PROPERTY.
          WHEN ‘1‘.
            INFOR_ALL-PROPERTY = ‘A‘.
          WHEN ‘2‘.
            INFOR_ALL-PROPERTY = ‘C‘.
          WHEN ‘3‘.
            INFOR_ALL-PROPERTY = ‘D‘.
          WHEN ‘4‘.
            INFOR_ALL-PROPERTY = ‘B‘.
          WHEN ‘5‘.
            INFOR_ALL-PROPERTY = ‘E‘.
          WHEN ‘6‘.
            INFOR_ALL-PROPERTY = ‘过保‘.
        ENDCASE.

        INFOR_ALL-APPLY_NUM = LEND_DETAIL-APPLY_NUM.
        INFOR_ALL-GET_NUM   = LEND_DETAIL-GET_NUM.
        INFOR_ALL-RETURN_NUM = LEND_DETAIL-RETURN_NUM.
        INFOR_ALL-NUM   = INFOR_ALL-GET_NUM - INFOR_ALL-RETURN_NUM .
        INFOR_ALL-APPLY_NO  = LEND_DETAIL-APPLY_NO.
        INFOR_ALL-MEINS     = LEND_DETAIL-MEINS.
        INFOR_ALL-PRICE     = LEND_DETAIL-PRICE.
        INFOR_ALL-TOTAL     = INFOR_ALL-PRICE * INFOR_ALL-APPLY_NUM .
        INFOR_ALL-SENDER    = LEND_DETAIL-SENDER.
        INFOR_ALL-STORER    = LEND_DETAIL-SOTRER.
        INFOR_ALL-MACHI_SERIES = LEND_DETAIL-MACHI_SERIES.
        CLEAR INFOR_ALL-RETURN_NO .
        SELECT RETURN_NO
         INTO INFOR_ALL-RETURN_NO FROM ZRETURN_INFOR
        WHERE LEND_NO = LEND_DETAIL-LEND_NO AND MATNR = LEND_DETAIL-MATNR .
        ENDSELECT.
        APPEND INFOR_ALL.
      ENDIF.
    ENDLOOP.
  ENDLOOP.
  SORT INFOR_ALL BY PURPOSE.
  CLEAR FIELDCAT[].
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME     = ‘LEND_NO‘.
  FIELDCAT-TABNAME       = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S     = ‘借料单号‘.
  FIELDCAT-SELTEXT_M     = ‘借料单号‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME   = ‘LEND_DEPART‘.
  FIELDCAT-TABNAME     = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S   = ‘部门代码‘.
  FIELDCAT-SELTEXT_M   = ‘部门代码‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME   = ‘LEND_DEP‘.
  FIELDCAT-TABNAME     = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S   = ‘借料部门‘.
  FIELDCAT-SELTEXT_M   = ‘借料部门‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME  = ‘LEND_DATE‘.
  FIELDCAT-TABNAME    = ‘LEND_MAIN‘.
  FIELDCAT-SELTEXT_S  = ‘借料日期‘.
  FIELDCAT-SELTEXT_M  = ‘借料日期‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘RETURN_DATE‘.
  FIELDCAT-TABNAME   = ‘LEND_MAIN‘.
  FIELDCAT-SELTEXT_S = ‘预计归还日期‘.
  FIELDCAT-SELTEXT_M = ‘预计归还日期‘.
  APPEND FIELDCAT.
*  fieldcat-fieldname = ‘RETURN_DATE‘.
*  fieldcat-tabname   = ‘EXT_ITAB‘.
*  fieldcat-seltext_s = ‘已还日期‘.
*  fieldcat-seltext_m = ‘已还日期‘.
*  append fieldcat.
  FIELDCAT-FIELDNAME = ‘PURPOSE‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘用途‘.
  FIELDCAT-SELTEXT_M = ‘用途‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘PUR_DETAIL‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘用途详细‘.
  FIELDCAT-SELTEXT_M = ‘用途详细‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MANAGER1‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘审批经理‘.
  FIELDCAT-SELTEXT_M = ‘审批经理‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘OPERATOR‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘操作人‘.
  FIELDCAT-SELTEXT_M = ‘操作人‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MATNR‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘物料号‘.
  FIELDCAT-SELTEXT_M = ‘物料号‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MAKTX‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘物料描述‘.
  FIELDCAT-SELTEXT_M = ‘物料描述‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MEINS‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘单位‘.
  FIELDCAT-SELTEXT_M = ‘单位‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘STORE_TYPE‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘库类别‘.
  FIELDCAT-SELTEXT_M = ‘库类别‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘PROPERTY‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘物料属性‘.
  FIELDCAT-SELTEXT_M = ‘物料属性‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘APPLY_NUM‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘申请数量‘.
  FIELDCAT-SELTEXT_M = ‘申请数量‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘GET_NUM‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘发货数量‘.
  FIELDCAT-SELTEXT_M = ‘发货数量‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘RETURN_NUM‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘归还数量‘.
  FIELDCAT-SELTEXT_M = ‘归还数量‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘NUM‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘余额‘.
  FIELDCAT-SELTEXT_M = ‘余额‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘LENDER‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘借物人‘.
  FIELDCAT-SELTEXT_M = ‘借物人‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘PRICE‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘单价‘.
  FIELDCAT-SELTEXT_M = ‘单价‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘TOTAL‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘金额‘.
  FIELDCAT-SELTEXT_M = ‘金额‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘APPLY_NO‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘申请单号‘.
  FIELDCAT-SELTEXT_M = ‘申请单号‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MACHI_SERIES‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘机器序列号‘.
  FIELDCAT-SELTEXT_M = ‘机器序列号‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘RETURN_NO‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘还物单号‘.
  FIELDCAT-SELTEXT_M = ‘还物单号‘.
  APPEND FIELDCAT.

  CALL FUNCTION ‘REUSE_ALV_GRID_DISPLAY‘
    EXPORTING
      IT_FIELDCAT = FIELDCAT[]
      I_DEFAULT   = ‘X‘
      I_SAVE      = ‘A‘
    TABLES
      T_OUTTAB    = INFOR_ALL
    EXCEPTIONS
      OTHERS      = 2.
ENDFORM.                    "pur_data
*&--------------------------------------------------------------------*
*&      Form  get_line_no
*&--------------------------------------------------------------------*
*       text
*---------------------------------------------------------------------*
FORM GET_LINE_NO .
  CALL FUNCTION ‘NUMBER_GET_NEXT‘
    EXPORTING
      NR_RANGE_NR             = ‘1‘
      OBJECT                  = ‘ZJHW_LLD2‘
    IMPORTING
      NUMBER                  = LLD_NO
    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.
ENDFORM.                    "get_line_no
*&--------------------------------------------------------------------*
*&      Form  GET_HLD_NO
*&--------------------------------------------------------------------*
*       text
*---------------------------------------------------------------------*
FORM GET_HLD_NO .
  CALL FUNCTION ‘NUMBER_GET_NEXT‘
    EXPORTING
      NR_RANGE_NR             = ‘1‘
      OBJECT                  = ‘ZJHW_HLD2‘
    IMPORTING
      NUMBER                  = HLD_NO
    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.
ENDFORM.                    "GET_HLD_NO
*&--------------------------------------------------------------------*
*&      Form  return_data
*&--------------------------------------------------------------------*
*       text
*---------------------------------------------------------------------*
FORM RETURN_DATA."从已还物库RETURN_INFOR统计信息
*  if r_date-low <> 0 and r_date-high <> 0 .
*    if itab is initial .
*    concatenate ‘return_date between ‘ ‘ r_date-low ‘ ‘
*    and ‘ ‘ r_date-high ‘ into itab.
*    else.
*      concatenate ‘ and return_date between ‘ ‘ r_date-low ‘ ‘
*       and ‘ ‘ r_date-high ‘ into itab.
*    endif.
*    append itab.
*  endif.
  IF SY-UNAME = ‘YAOJL‘ OR SY-UNAME = ‘ZHANGSHP‘ OR SY-UNAME =
‘YINGZHAO‘.
    NAME = ‘2000‘.
    IF ITAB IS INITIAL.
      CONCATENATE ‘RETURN_DEPART = ‘ ‘ NAME ‘INTO ITAB.
    ELSE.
      CONCATENATE ‘ AND RETURN_DEPART = ‘ ‘ NAME ‘INTO ITAB.
    ENDIF.
    APPEND ITAB.
    CLEAR DEPART.
  ENDIF.
*  if depart <> ‘‘ .
*    if itab is initial.
*      concatenate ‘return_depart = ‘ ‘ depart ‘ into itab.
*    else.
*      concatenate ‘ and return_depart = ‘ ‘ depart ‘ into itab.
*    endif.
*    append itab.
*  endif.
*  if R_NO <> ‘‘ .
*    if itab is initial.
*       concatenate ‘return_no = ‘ ‘ R_NO ‘ into itab.
*     else.
*       concatenate ‘ and  return_no = ‘ ‘ R_NO ‘ into itab.
*     endif.
*     append itab.
*  endif.
  CLEAR RETURN_DAT[].
  SELECT * INTO TABLE RETURN_DAT FROM
  ZRETURN_INFOR WHERE RETURN_DEPART IN DEPART AND LEND_NO IN NO
   AND RETURN_NO IN R_NO AND RETURN_DATE IN R_DATE AND (ITAB).
  SORT RETURN_DAT BY RETURN_NO .
  CLEAR INFOR_ALL[].
  CLEAR INFOR_ALL.
  LOOP AT RETURN_DAT.
    CLEAR INFOR_ALL-TOTAL.
    CLEAR INFOR_ALL-LEND_DEP.
    INFOR_ALL-LEND_NO = RETURN_DAT-LEND_NO .
    INFOR_ALL-TOTAL = RETURN_DAT-RETURN_NUM * RETURN_DAT-PRICE .
*    select brtxt into infor_all-lend_dep from t016t where brsch =
*return_dat-RETURN_depart .
*    endselect.
    SELECT BRTXT INTO RETURN_DATA-BN3 FROM ZT016T WHERE BRSCH =
RETURN_DAT-RETURN_DEPART AND SPRAS = ‘1‘.
    ENDSELECT.
*    append infor_all.

    CASE RETURN_DAT-STORE_TYPE.
      WHEN ‘1‘.
        RETURN_DAT-STORE_TYPE = ‘SER整机库‘.
      WHEN ‘2‘.
        RETURN_DAT-STORE_TYPE = ‘SER散件库‘.
      WHEN ‘3‘.
        RETURN_DAT-STORE_TYPE = ‘PC整机库‘.
      WHEN ‘4‘.
        RETURN_DAT-STORE_TYPE = ‘PC散件库‘.
      WHEN ‘5‘.
        RETURN_DAT-STORE_TYPE = ‘PC显示器‘.
      WHEN ‘6‘.
        RETURN_DAT-STORE_TYPE = ‘SER显示器‘.
    ENDCASE.

    CASE RETURN_DAT-PROPERTY.
      WHEN ‘1‘.
        RETURN_DAT-PROPERTY = ‘A‘.
      WHEN ‘2‘.
        RETURN_DAT-PROPERTY = ‘C‘.
      WHEN ‘3‘.
        RETURN_DAT-PROPERTY = ‘D‘.
      WHEN ‘4‘.
        RETURN_DAT-PROPERTY = ‘B‘.
      WHEN ‘5‘.
        RETURN_DAT-PROPERTY = ‘E‘.
      WHEN ‘6‘.
        RETURN_DAT-PROPERTY = ‘过保‘.
    ENDCASE.
    MODIFY RETURN_DAT .
  ENDLOOP.
  CLEAR FIELDCAT[].
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME     = ‘LEND_NO‘.
  FIELDCAT-TABNAME       = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S     = ‘借料单号‘.
  FIELDCAT-SELTEXT_M     = ‘借料单号‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME   = ‘RETURN_DEPART‘.
  FIELDCAT-TABNAME     = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S   = ‘部门代码‘.
  FIELDCAT-SELTEXT_M   = ‘部门代码‘.
  APPEND FIELDCAT.
*  fieldcat-fieldname   = ‘LEND_DEP‘.
*  fieldcat-tabname     = ‘INFOR_ALL‘.
*  fieldcat-seltext_s   = ‘借料部门‘.
*  fieldcat-seltext_m   = ‘借料部门‘.
*  append fieldcat.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME   = ‘BN3‘.
  FIELDCAT-TABNAME     = ‘RETURN_DATA‘.
  FIELDCAT-SELTEXT_S   = ‘借料部门‘.
  FIELDCAT-SELTEXT_M   = ‘借料部门‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME   = ‘DEP_DETAIL‘.
  FIELDCAT-TABNAME     = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S   = ‘部门明细‘.
  FIELDCAT-SELTEXT_M   = ‘部门明细‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME  = ‘RETURN_DATE‘.
  FIELDCAT-TABNAME    = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S  = ‘还物日期‘.
  FIELDCAT-SELTEXT_M  = ‘还物日期‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘STORE_TYPE‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘库类别‘.
  FIELDCAT-SELTEXT_M = ‘库类别‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘PROPERTY‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘物料属性‘.
  FIELDCAT-SELTEXT_M = ‘物料属性‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MANAGER1‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘审批经理‘.
  FIELDCAT-SELTEXT_M = ‘审批经理‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘OPERATOR‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘操作人‘.
  FIELDCAT-SELTEXT_M = ‘操作人‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MATNR‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘物料号‘.
  FIELDCAT-SELTEXT_M = ‘物料号‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MAKTX‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘物料描述‘.
  FIELDCAT-SELTEXT_M = ‘物料描述‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MEINS‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘单位‘.
  FIELDCAT-SELTEXT_M = ‘单位‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘RETURN_NUM‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘归还数量‘.
  FIELDCAT-SELTEXT_M = ‘归还数量‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘RETURNER‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘借物人‘.
  FIELDCAT-SELTEXT_M = ‘借物人‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘PRICE‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘单价‘.
  FIELDCAT-SELTEXT_M = ‘单价‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘TOTAL‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘金额‘.
  FIELDCAT-SELTEXT_M = ‘金额‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘APPLY_NO‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘申请单号‘.
  FIELDCAT-SELTEXT_M = ‘申请单号‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MACHI_SERIES‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘机器序列号‘.
  FIELDCAT-SELTEXT_M = ‘机器序列号‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘CHECKER‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘检验人员‘.
  FIELDCAT-SELTEXT_M = ‘检验人员‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘DETAIL‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘检验明细‘.
  FIELDCAT-SELTEXT_M = ‘检验明细‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘CHECK_DETAIL‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘检验结果‘.
  FIELDCAT-SELTEXT_M = ‘检验结果‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘NEW_CPBM‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘新产品编码‘.
  FIELDCAT-SELTEXT_M = ‘新产品编码‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘NEW_WLMS‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘新物料描述‘.
  FIELDCAT-SELTEXT_M = ‘新物料描述‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘NEW_WLSX‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘新物料属性‘.
  FIELDCAT-SELTEXT_M = ‘新物料属性‘.
  APPEND FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘RETURN_NO‘.
  FIELDCAT-TABNAME   = ‘RETURN_DAT‘.
  FIELDCAT-SELTEXT_S = ‘还物单号‘.
  FIELDCAT-SELTEXT_M = ‘还物单号‘.
  APPEND FIELDCAT.

  CALL FUNCTION ‘REUSE_ALV_GRID_DISPLAY‘
    EXPORTING
      IT_FIELDCAT = FIELDCAT[]
      I_DEFAULT   = ‘X‘
      I_SAVE      = ‘A‘
    TABLES
      T_OUTTAB    = RETURN_DAT
    EXCEPTIONS
      OTHERS      = 2.
ENDFORM.                    "return_data
*&--------------------------------------------------------------------*
*&      Form  time_data
*&--------------------------------------------------------------------*
*       text
*---------------------------------------------------------------------*
FORM TIME_DATA ."按照还物日期统计
  IF SY-UNAME = ‘YINGZHAO‘ OR SY-UNAME = ‘ZHANGSHP‘ OR SY-UNAME =
‘YAOLJ‘.
    NAME = ‘2000‘.
    IF ITAB IS INITIAL.
      CONCATENATE ‘RETURN_DEPART = ‘ ‘ NAME ‘INTO ITAB.
    ELSE.
      CONCATENATE ‘ AND RETURN_DEPART = ‘ ‘ NAME ‘INTO ITAB.
    ENDIF.
    APPEND ITAB.
    CLEAR DEPART.
  ENDIF.
  REFRESH RETURN_DAT.
  CLEAR RETURN_DAT.
  REFRESH INFOR_ALL.
  CLEAR INFOR_ALL.
  SELECT * INTO TABLE RETURN_DAT FROM
  ZRETURN_INFOR WHERE RETURN_DEPART IN DEPART AND LEND_NO IN NO
   AND RETURN_NO IN R_NO AND RETURN_DATE IN R_DATE AND (ITAB).
  SORT RETURN_DAT BY LEND_NO  .
  LOOP AT RETURN_DAT.
    INFOR_ALL-RETURN_NO = RETURN_DAT-RETURN_NO.
    INFOR_ALL-LEND_DEPART = RETURN_DAT-RETURN_DEPART.
    CLEAR INFOR_ALL-LEND_DEP.
    SELECT BRTXT INTO INFOR_ALL-LEND_DEP FROM ZT016T WHERE BRSCH =
RETURN_DAT-RETURN_DEPART AND SPRAS = ‘1‘ .
    ENDSELECT.
    INFOR_ALL-DEP_DETAIL  = RETURN_DAT-DEP_DETAIL.
    INFOR_ALL-RETURN_DATE = RETURN_DAT-RETURN_DATE.
    CASE RETURN_DAT-STORE_TYPE.
      WHEN ‘1‘.
        INFOR_ALL-STORE_TYPE = ‘SER整机库‘.
      WHEN ‘2‘.
        INFOR_ALL-STORE_TYPE = ‘SER散件库‘.
      WHEN ‘3‘.
        INFOR_ALL-STORE_TYPE = ‘PC整机库‘.
      WHEN ‘4‘.
        INFOR_ALL-STORE_TYPE = ‘PC散件库‘.
      WHEN ‘5‘.
        INFOR_ALL-STORE_TYPE = ‘PC显示器‘.
      WHEN ‘6‘.
        INFOR_ALL-STORE_TYPE = ‘SER显示器‘.
    ENDCASE.

    CASE RETURN_DAT-PROPERTY.
      WHEN ‘1‘.
        INFOR_ALL-PROPERTY = ‘A‘.
      WHEN ‘2‘.
        INFOR_ALL-PROPERTY = ‘C‘.
      WHEN ‘3‘.
        INFOR_ALL-PROPERTY = ‘D‘.
      WHEN ‘4‘.
        INFOR_ALL-PROPERTY = ‘B‘.
      WHEN ‘5‘.
        INFOR_ALL-PROPERTY = ‘E‘.
      WHEN ‘6‘.
        INFOR_ALL-PROPERTY = ‘过保‘.
    ENDCASE.
    INFOR_ALL-MANAGER1    = RETURN_DAT-MANAGER1.
    INFOR_ALL-LENDER      = RETURN_DAT-CHECKER.
    INFOR_ALL-OPERATOR    = RETURN_DAT-OPERATOR.
    INFOR_ALL-MATNR       = RETURN_DAT-MATNR.
    INFOR_ALL-MAKTX       = RETURN_DAT-MAKTX.
    INFOR_ALL-ZTBS        = RETURN_DAT-ZTBS.
*     infor_all-apply_num = lend_detail-apply_num.
*     infor_all-get_num   = lend_detail-get_num.
    INFOR_ALL-RETURN_NUM  = RETURN_DAT-RETURN_NUM.

    IF INFOR_ALL-LEND_NO = RETURN_DAT-LEND_NO .
      CLEAR INFOR_ALL-GET_NUM.
      CLEAR INFOR_ALL-NUM.
    ELSE.
      SELECT GET_NUM INTO INFOR_ALL-GET_NUM  FROM ZLEND_DETAIL
      WHERE LEND_NO = RETURN_DAT-LEND_NO AND
      MATNR = RETURN_DAT-MATNR.
      ENDSELECT."发或数量
      SELECT RETURN_NUM INTO INFOR_ALL-APPLY_NUM FROM
      ZLEND_DETAIL WHERE LEND_NO = RETURN_DAT-LEND_NO AND
      MATNR = RETURN_DAT-MATNR.
      ENDSELECT."归还数量
      INFOR_ALL-NUM   = INFOR_ALL-GET_NUM - INFOR_ALL-APPLY_NUM .
    ENDIF.
    INFOR_ALL-LEND_NO   = RETURN_DAT-LEND_NO.
    INFOR_ALL-APPLY_NO  = RETURN_DAT-APPLY_NO.
    INFOR_ALL-MEINS     = RETURN_DAT-MEINS.
    INFOR_ALL-PRICE     = RETURN_DAT-PRICE.
    INFOR_ALL-TOTAL     = INFOR_ALL-PRICE * INFOR_ALL-GET_NUM .
    INFOR_ALL-STORER    = RETURN_DAT-STORER.
    INFOR_ALL-MACHI_SERIES = RETURN_DAT-MACHI_SERIES.
    APPEND INFOR_ALL.
  ENDLOOP.
  SORT INFOR_ALL BY LEND_NO.
  REFRESH FIELDCAT.
  CLEAR FIELDCAT.
  FIELDCAT-FIELDNAME = ‘RETURN_NO‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘还物单号‘.
  FIELDCAT-SELTEXT_M = ‘还物单号‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME     = ‘LEND_NO‘.
  FIELDCAT-TABNAME       = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S     = ‘借料单号‘.
  FIELDCAT-SELTEXT_M     = ‘借料单号‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME   = ‘LEND_DEPART‘.
  FIELDCAT-TABNAME     = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S   = ‘部门代码‘.
  FIELDCAT-SELTEXT_M   = ‘部门代码‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME   = ‘LEND_DEP‘.
  FIELDCAT-TABNAME     = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S   = ‘部门名称‘.
  FIELDCAT-SELTEXT_M   = ‘部门名称‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME   = ‘DEP_DETAIL‘.
  FIELDCAT-TABNAME     = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S   = ‘部门明细‘.
  FIELDCAT-SELTEXT_M   = ‘部门明细‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME  = ‘RETURN_DATE‘.
  FIELDCAT-TABNAME    = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S  = ‘还物日期‘.
  FIELDCAT-SELTEXT_M  = ‘还物日期‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘STORE_TYPE‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘库类别‘.
  FIELDCAT-SELTEXT_M = ‘库类别‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘PROPERTY‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘物料属性‘.
  FIELDCAT-SELTEXT_M = ‘物料属性‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MANAGER1‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘审批经理‘.
  FIELDCAT-SELTEXT_M = ‘审批经理‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘OPERATOR‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘操作人‘.
  FIELDCAT-SELTEXT_M = ‘操作人‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MATNR‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘物料号‘.
  FIELDCAT-SELTEXT_M = ‘物料号‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MAKTX‘.
  FIELDCAT-TABNAME   = ‘INFRO_ALL‘.
  FIELDCAT-SELTEXT_S = ‘物料描述‘.
  FIELDCAT-SELTEXT_M = ‘物料描述‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MEINS‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘单位‘.
  FIELDCAT-SELTEXT_M = ‘单位‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘NUM‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘剩余数量‘.
  FIELDCAT-SELTEXT_M = ‘剩余数量‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘RETURN_NUM‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘归还数量‘.
  FIELDCAT-SELTEXT_M = ‘归还数量‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘LENDER‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘借物人‘.
  FIELDCAT-SELTEXT_M = ‘借物人‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘PRICE‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘单价‘.
  FIELDCAT-SELTEXT_M = ‘单价‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘TOTAL‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘金额‘.
  FIELDCAT-SELTEXT_M = ‘金额‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘APPLY_NO‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘申请单号‘.
  FIELDCAT-SELTEXT_M = ‘申请单号‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘MACHI_SERIES‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘机器序列号‘.
  FIELDCAT-SELTEXT_M = ‘机器序列号‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘CHECKER‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘检验人员‘.
  FIELDCAT-SELTEXT_M = ‘检验人员‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘DETAIL‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘检验明细‘.
  FIELDCAT-SELTEXT_M = ‘检验明细‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘CHECK_DETAIL‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘检验结果‘.
  FIELDCAT-SELTEXT_M = ‘检验结果‘.
  APPEND FIELDCAT.
  FIELDCAT-FIELDNAME = ‘STORER‘.
  FIELDCAT-TABNAME   = ‘INFOR_ALL‘.
  FIELDCAT-SELTEXT_S = ‘库管人员‘.
  FIELDCAT-SELTEXT_M = ‘库管人员‘.
  APPEND FIELDCAT.
*  fieldcat-fieldname = ‘NEW_CPBM‘.
*  fieldcat-tabname   = ‘RETURN_DAT‘.
*  fieldcat-seltext_s = ‘新产品编码‘.
*  fieldcat-seltext_m = ‘新产品编码‘.
*  append fieldcat.
*  fieldcat-fieldname = ‘NEW_WLMS‘.
*  fieldcat-tabname   = ‘RETURN_DAT‘.
*  fieldcat-seltext_s = ‘新物料描述‘.
*  fieldcat-seltext_m = ‘新物料描述‘.
*  append fieldcat.
*  fieldcat-fieldname = ‘NEW_WLSX‘.
*  fieldcat-tabname   = ‘RETURN_DAT‘.
*  fieldcat-seltext_s = ‘新物料属性‘.
*  fieldcat-seltext_m = ‘新物料属性‘.
*  append fieldcat.


  CALL FUNCTION ‘REUSE_ALV_GRID_DISPLAY‘
    EXPORTING
      IT_FIELDCAT = FIELDCAT[]
      I_DEFAULT   = ‘X‘
      I_SAVE      = ‘A‘
    TABLES
      T_OUTTAB    = INFOR_ALL
    EXCEPTIONS
      OTHERS      = 2.
ENDFORM.                    "time_dat



*&--------------------------------------------------------------------*
*&      Form  WRITE_STRING
*&--------------------------------------------------------------------*
*       text
*---------------------------------------------------------------------*
*      -->LEND_MAIN-Btext
*      -->B1         text
*      -->B2         text
*---------------------------------------------------------------------*
FORM WRITE_STRING USING    LEND_MAIN-BZ
CHANGING B1
        B2.
  CONSTANTS: V_A2 TYPE X VALUE ‘7F‘.
  DATA: V_A3 TYPE X  .
  DATA: J TYPE I, COUNT01 TYPE I.
  DO 56 TIMES.
    V_A3 = LEND_MAIN-BZ+J(1).
    FIELD-SYMBOLS: <DUMMY>.
    ASSIGN LEND_MAIN-BZ+J(1)  TO <DUMMY> TYPE ‘X‘.
    IF  <DUMMY>   > V_A2.
      COUNT01 = COUNT01 + 1.
    ENDIF.
    J = J + 1.
  ENDDO.
  COUNT01 = COUNT01 MOD 2.
  IF COUNT01 EQ 0.
    B1 = LEND_MAIN-BZ+0(56).
    B2 = LEND_MAIN-BZ+56(54).
  ELSE.
    B1 = LEND_MAIN-BZ+0(55).
    B2 = LEND_MAIN-BZ+55(55).
  ENDIF.
ENDFORM.                    "WRITE_STRING

abap中,利用write进行表单打印示例

标签:abap中   利用write进行表单打印示例   

原文地址:http://blog.csdn.net/champaignwolf/article/details/45218185

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!