REPORT  Z_CREATE_PR.

DATA: BEGIN OF GT_DATA1 OCCURS 0,
            BSART   TYPE STRING, "凭证类型
            BNFPO   TYPE STRING, "项目
*            KNTTP   TYPE STRING, "科目分配类别
            MATNR   TYPE STRING,  "商品代码
*            TXZ01   TYPE STRING, "短文本
            MENGE   TYPE STRING, "数量
            MEINS   TYPE STRING, "单位
            EEIND   TYPE STRING, "交货日期
*            MATKL   TYPE STRING, "物料组
            WERKS   TYPE STRING, "工厂
            EKGRP   TYPE STRING, "采购组
            AFNAM   TYPE STRING, "申请者
            BEDNR   TYPE STRING, "需求跟踪号
            SAKTO   TYPE STRING, "总帐科目
            KOSTL   TYPE STRING, "成本中心
            ANLN1   TYPE STRING, "资产
            AUFNR   TYPE STRING, "订单
            PREIS   TYPE STRING,  "评估价格
            WAERS   TYPE STRING, "币种
            PEINH   TYPE STRING, "价格单位
            DISPO   TYPE STRING, "MRP控制者
            STR1    TYPE STRING,"行项目文本-传送文本
            STR2    TYPE STRING,"行项目文本-预算年度
            STR3    TYPE STRING,"行项目文本-资产类别
        END OF GT_DATA1.

DATA: BEGIN OF GT_DATA OCCURS 0,
            BEDNR   TYPE STRING, "需求跟踪号
            BSART   TYPE STRING, "凭证类型
            BNFPO   TYPE STRING, "项目
*            KNTTP   TYPE STRING, "科目分配类别
            MATNR   TYPE STRING,  "商品代码
*            TXZ01   TYPE STRING, "短文本
            MENGE   TYPE STRING, "数量
            MEINS   TYPE STRING, "单位
            EEIND   TYPE STRING, "交货日期
*            MATKL   TYPE STRING, "物料组
            WERKS   TYPE STRING, "工厂
            EKGRP   TYPE STRING, "采购组
            AFNAM   TYPE STRING, "申请者
            SAKTO   TYPE STRING, "总帐科目
            KOSTL   TYPE STRING, "成本中心
            ANLN1   TYPE STRING, "资产
            AUFNR   TYPE STRING, "订单
            PREIS   TYPE STRING,  "评估价格
            WAERS   TYPE STRING, "币种
            PEINH   TYPE STRING, "价格单位
            DISPO   TYPE STRING, "MRP控制者
            STR1    TYPE STRING,"行项目文本-传送文本
            STR2    TYPE STRING,"行项目文本-预算年度
            STR3    TYPE STRING,"行项目文本-资产类别
        END OF GT_DATA.

DATA: BEGIN OF GT_OUT OCCURS 0,
            TEXT(255),
          END OF GT_OUT.

DATA: PR_ITEM LIKE TABLE OF  BAPIEBANC WITH HEADER LINE,
          PR_ACCOUNT LIKE TABLE OF BAPIEBKN WITH HEADER LINE,
          PR_ITEM_ID LIKE TABLE OF BAPIEBANTX WITH HEADER LINE,
          PR_RETURN LIKE TABLE OF BAPIRETURN WITH HEADER LINE.
DATA: L_RETURN LIKE PR_RETURN.
DATA: LV_MESSAGE(255).

DATA: PR_NO TYPE BAPIEBANC-PREQ_NO.
DATA: BNFPO TYPE BNFPO.
DATA: MATNR TYPE MATNR.
DATA: PP_FILE TYPE STRING.

PARAMETERS:P_FILE(128) .

AT SELECTION-SCREEN ON VALUE-REQUEST FOR P_FILE.
  PERFORM GET_FILE.

START-OF-SELECTION.
  PERFORM GET_DATA.
  PERFORM CREATE_PR.
  PERFORM WRITE_OUT.
*&---------------------------------------------------------------------*
*&      Form  GET_FILE
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM GET_FILE .
  CALL FUNCTION 'WS_FILENAME_GET'
       EXPORTING
            DEF_FILENAME     = P_FILE
            MASK             = ',*.txt,*.TXT.'
*'',*.xls,*.XLS.'如果读入txt文件,在后边就需要用函数
*  CALL FUNCTION 'WS_UPLOAD'
            MODE             = 'O'
            TITLE            = 'File Name'
       IMPORTING
            FILENAME         =  P_FILE
       EXCEPTIONS
            INV_WINSYS       = 1
            NO_BATCH         = 2
            SELECTION_CANCEL = 3
            SELECTION_ERROR  = 4
            OTHERS           = 5.
  PP_FILE = P_FILE.

ENDFORM.                    " GET_FILE
*&---------------------------------------------------------------------*
*&      Form  GET_DATA
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM GET_DATA .
  CALL FUNCTION 'GUI_UPLOAD'
    EXPORTING
      FILENAME                      = PP_FILE
     FILETYPE                      = 'ASC'
     HAS_FIELD_SEPARATOR           = 'X'
*   HEADER_LENGTH                 = 0
     READ_BY_LINE                  = 'X'
*   DAT_MODE                      = ' '
*   CODEPAGE                      = ' '
*   IGNORE_CERR                   = ABAP_TRUE
*   REPLACEMENT                   = '#'
*   CHECK_BOM                     = ' '
*   VIRUS_SCAN_PROFILE            =
*   NO_AUTH_CHECK                 = ' '
* IMPORTING
*   FILELENGTH                    =
*   HEADER                        =
    TABLES
      DATA_TAB                      = GT_DATA1
   EXCEPTIONS
     FILE_OPEN_ERROR               = 1
     FILE_READ_ERROR               = 2
     NO_BATCH                      = 3
     GUI_REFUSE_FILETRANSFER       = 4
     INVALID_TYPE                  = 5
     NO_AUTHORITY                  = 6
     UNKNOWN_ERROR                 = 7
     BAD_DATA_FORMAT               = 8
     HEADER_NOT_ALLOWED            = 9
     SEPARATOR_NOT_ALLOWED         = 10
     HEADER_TOO_LONG               = 11
     UNKNOWN_DP_ERROR              = 12
     ACCESS_DENIED                 = 13
     DP_OUT_OF_MEMORY              = 14
     DISK_FULL                     = 15
     DP_TIMEOUT                    = 16
     OTHERS                        = 17
            .
  IF SY-SUBRC <> 0.
    CASE SY-SUBRC.
      WHEN 1.MESSAGE 'FILE_OPEN_ERROR ' TYPE 'E'.
      WHEN 2.MESSAGE 'FILE_READ_ERROR ' TYPE 'E'.
      WHEN 3.MESSAGE 'NO_BATCH' TYPE 'E'.
      WHEN 4.MESSAGE 'GUI_REFUSE_FILETRANSFER  ' TYPE 'E'.
      WHEN 5.MESSAGE 'INVALID_TYPE ' TYPE 'E'.
      WHEN 6.MESSAGE ' NO_AUTHORITY' TYPE 'E'.
      WHEN 7.MESSAGE 'UNKNOWN_ERROR' TYPE 'E'.
      WHEN 8.MESSAGE 'BAD_DATA_FORMAT ' TYPE 'E'.
      WHEN 9.MESSAGE 'HEADER_NOT_ALLOWED' TYPE 'E'.
      WHEN 10.MESSAGE 'SEPARATOR_NOT_ALLOWED' TYPE 'E'.
      WHEN 11.MESSAGE 'HEADER_TOO_LONG ' TYPE 'E'.
      WHEN 12.MESSAGE 'UNKNOWN_DP_ERROR' TYPE 'E'.
      WHEN 13.MESSAGE ' ACCESS_DENIED ' TYPE 'E'.
      WHEN 14.MESSAGE 'DP_OUT_OF_MEMORY ' TYPE 'E'.
      WHEN 15.MESSAGE 'DISK_FULL  ' TYPE 'E'.
      WHEN 16.MESSAGE 'DP_TIMEOUT' TYPE 'E'.
      WHEN 17.MESSAGE ' OTHERS  ' TYPE 'E'.
      WHEN OTHERS.
    ENDCASE.
* MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
*         WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
  ENDIF.
  LOOP AT GT_DATA1.
    MOVE-CORRESPONDING GT_DATA1 TO GT_DATA.
    APPEND GT_DATA.
    CLEAR: GT_DATA,GT_DATA1.
  ENDLOOP.
ENDFORM.                    " GET_DATA
*&---------------------------------------------------------------------*
*&      Form  CREATE_PR
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM CREATE_PR .
  LOOP AT GT_DATA.
    BNFPO = GT_DATA-BNFPO.
    CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
      EXPORTING
        INPUT  = BNFPO
      IMPORTING
        OUTPUT = BNFPO.
    CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
      EXPORTING
        INPUT  = GT_DATA-MATNR
      IMPORTING
        OUTPUT = MATNR.
    PR_ITEM-DOC_TYPE   = GT_DATA-BSART. "凭证类型
    PR_ITEM-PREQ_ITEM  = BNFPO. "项目
*    PR_ITEM-ACCTASSCAT = GT_DATA-KNTTP."科目分配类别
    PR_ITEM-MATERIAL = MATNR."商品代码
*    PR_ITEM-SHORT_TEXT = GT_DATA-TXZ01."短文本
    PR_ITEM-QUANTITY  = GT_DATA-MENGE. "数量
    PR_ITEM-UNIT = GT_DATA-MEINS."单位
    PR_ITEM-DELIV_DATE = GT_DATA-EEIND.  "交货日期
*    PR_ITEM-MAT_GRP = GT_DATA-MATKL.   "物料组
    PR_ITEM-PLANT  = GT_DATA-WERKS."工厂
    PR_ITEM-PUR_GROUP = GT_DATA-EKGRP."采购组
    PR_ITEM-PREQ_NAME = GT_DATA-AFNAM."申请者
    PR_ITEM-TRACKINGNO = GT_DATA-BEDNR."需求跟踪号
    PR_ITEM-C_AMT_BAPI = GT_DATA-PREIS."评估价格
    PR_ITEM-CURRENCY = GT_DATA-WAERS."货币码
    PR_ITEM-PRICE_UNIT = GT_DATA-PEINH."价格单位
    PR_ITEM-MRP_CONTR = GT_DATA-DISPO."MRP控制者
    APPEND PR_ITEM.
    CLEAR PR_ITEM.

PR_ACCOUNT-PREQ_ITEM = BNFPO. "项目
    PR_ACCOUNT-G_L_ACCT = GT_DATA-SAKTO.   "总帐科目
    PR_ACCOUNT-COST_CTR = GT_DATA-KOSTL.  "成本中心
    PR_ACCOUNT-ASSET_NO = GT_DATA-ANLN1. "资产
    PR_ACCOUNT-ORDER_NO = GT_DATA-AUFNR. "订单
    PR_ACCOUNT-CO_AREA = 'BELL'.
    APPEND PR_ACCOUNT.
    CLEAR PR_ACCOUNT.

PR_ITEM_ID-PREQ_ITEM = BNFPO."项目
    PR_ITEM_ID-TEXT_ID = 'B03'.
    PR_ITEM_ID-TEXT_LINE = GT_DATA-STR1."行项目文本-传送文本
    APPEND PR_ITEM_ID.
    CLEAR PR_ITEM_ID.

PR_ITEM_ID-PREQ_ITEM = BNFPO."项目
    PR_ITEM_ID-TEXT_ID = 'B07'.
    PR_ITEM_ID-TEXT_LINE = GT_DATA-STR2."行项目文本-预算年度
    APPEND PR_ITEM_ID.
    CLEAR PR_ITEM_ID.

PR_ITEM_ID-PREQ_ITEM = BNFPO."项目
    PR_ITEM_ID-TEXT_ID = 'B08'.
    PR_ITEM_ID-TEXT_LINE = GT_DATA-STR3."行项目文本-资产类别
    APPEND  PR_ITEM_ID.
    CLEAR  PR_ITEM_ID.

AT END OF BEDNR.

CALL FUNCTION 'BAPI_REQUISITION_CREATE'
* EXPORTING
*   SKIP_ITEMS_WITH_ERROR                =
*   AUTOMATIC_SOURCE                     = 'X'
       IMPORTING
         NUMBER                               = PR_NO
        TABLES
          REQUISITION_ITEMS                    = PR_ITEM
          REQUISITION_ACCOUNT_ASSIGNMENT       = PR_ACCOUNT
          REQUISITION_ITEM_TEXT                = PR_ITEM_ID
*   REQUISITION_LIMITS                   =
*   REQUISITION_CONTRACT_LIMITS          =
*   REQUISITION_SERVICES                 =
*   REQUISITION_SRV_ACCASS_VALUES        =
          RETURN                               = PR_RETURN
*   REQUISITION_SERVICES_TEXT            =
*   REQUISITION_ADDRDELIVERY             =
*   EXTENSIONIN                          =
                .
      LOOP AT PR_RETURN WHERE TYPE = 'E' OR TYPE = 'A'.
      ENDLOOP.
      IF SY-SUBRC = 0.
        CLEAR: LV_MESSAGE.
        CALL FUNCTION 'BAPI_TRANSACTION_ROLLBACK'.
        LOOP AT PR_RETURN INTO L_RETURN WHERE TYPE = 'E' .
          CONCATENATE LV_MESSAGE L_RETURN-MESSAGE ';'
            INTO LV_MESSAGE.
        ENDLOOP.
        CONCATENATE GT_DATA-BEDNR LV_MESSAGE INTO GT_OUT-TEXT.
        APPEND GT_OUT.
        CLEAR GT_OUT.
      ELSE.
        CALL FUNCTION 'BAPI_TRANSACTION_COMMIT'
          EXPORTING
            WAIT = 'X'.
        CONCATENATE PR_NO '创建成功' INTO GT_OUT-TEXT.
        APPEND GT_OUT.
        CLEAR GT_OUT.
      ENDIF.
      FREE PR_ITEM.
      FREE PR_ACCOUNT.
      FREE PR_ITEM_ID.
      FREE PR_RETURN.

ENDAT.
  ENDLOOP.

ENDFORM.                    " CREATE_PR
*&---------------------------------------------------------------------*
*&      Form  WRITE_OUT
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM WRITE_OUT .
  LOOP AT GT_OUT.
    WRITE: / GT_OUT-TEXT.
  ENDLOOP.
ENDFORM.                    " WRITE_OUT

 
以下为数据格式(行项目以回车键换行,列以TAB分隔):
ZB 10 100009 10 EA 20100915 D005
ZB 10 100008 10 EA 20100915 D005

PR 创建的更多相关文章

  1. 如何参与开源项目 - 细说 GitHub 上的 PR 全过程

    目录 一.概述 二.为什么要参与开源项目 三.为什么我想介绍如何 PR 四.我想参与开源项目,怎么开始? 4.1.寻找一个合适的开源项目 4.2.寻找贡献点 五.我要提交 PR,怎么上手? 5.1.第 ...

  2. 合并Spark社区代码的正确姿势

    原创文章,转载请保留出处 最近刚刚忙完Spark 2.2.0的性能测试及Bug修复,社区又要发布2.1.2了,国庆期间刚好有空,过了一遍2.1.2的相关JIRA,发现有不少重要修复2.2.0也能用上, ...

  3. 所有标准API

    序号 系统版本 模块 应用场景 类型 API/接口 参数规格 样例代码 备注 登记者 登记时间 关键字 1 12.1.3 AP 付款核销 API ap_pay_invoice_pkg.ap_pay_i ...

  4. Docker实战:更轻松、更愉快、更高效

    编者按:借助Docker,我们可以更容易地进行web应用部署,而同时不必头疼于项目依赖.环境变量以及各种配置问题,Docker可以快捷.高效地处理好这一切.而这也是本教程所要实现的主要目的.以下是作者 ...

  5. 10年经验17张图带你进入gitflow企业项目代码版本管理的最佳实践

    前言 对于项目版本管理,你是否存在这样的痛点:项目分支多而杂不好管理,git log界面commit信息错乱复杂无规范,版本回退不知道选择什么版本合适--. 项目版本管理的最佳实践系列,笔者将以两篇文 ...

  6. Visual Studio 2019 v16.10 和 v16.11 Preview 1 现已推出!

    Visual Studio 2019 v16.10有什么新功能? 我们很高兴地宣布Visual Studio 2019 v16.10 GA 和 v16.11 preview 1发布.此版本使我们的主题 ...

  7. 1.5 外部销售自动创建为内部PR

    1.5          外部销售自动创建为内部PR 1.5.1   业务方案描述 外部销售订单登记后,在销售订单录入界面点击一个创建内部申请按钮,自动将外部销售订单创建为内部申请,创建后将不得再次创 ...

  8. RFC 在OA中创建PR

    创建PR:BAPI_REQUISITION_CREATE BAPI_PR_CREATE                 "Create Enjoy Purchase Requisistion ...

  9. 如何在ASP.Net创建各种3D图表

    我们都知道,图表在ASP.NET技术中是一种特别受欢迎而又很重要的工具.图表是表示数据的图形,一般含有X和Y两个坐标轴.我们可以用折线,柱状,块状来表示数据.通过图表控件,我们即能表示数据又能比较各种 ...

随机推荐

  1. HDU 1394 Minimum Inversion Number

    //============================================================================ // Name : B.cpp // Au ...

  2. uiwebview 清缓存。,mark

    //清除cookies NSHTTPCookie *cookie; NSHTTPCookieStorage *storage = [NSHTTPCookieStorage sharedHTTPCook ...

  3. Linux 常用命令杂记

    移动光标:h:向左移动j:向下移动k:向上移动l:向上移动 与window 光标移动键功能一致. 常用命令行:shift + ^ 行首shift + $ 行尾ctrl + v 可视模式 , 选择一个范 ...

  4. [mr440] 崎岖的山区

    极类似动归的广搜?反正各种算法傻傻分不清…写之前叹了一句,好久不写广搜了啊!呵呵真的写了好久,大约一个钟头? f[i,j,0]表示到点(i,j)且最后一步为下降的最少步数,f[i,j,1]就是上升.莫 ...

  5. 宜家的幸福生活,源于K2 BPM的支撑

    很久很久以前,有一篇很火的文章在各大网站被疯狂转载<一个在北欧生活10年的MM,告诉你为什么北欧全球幸福指数第一>,开头第一段就已经让人羡慕嫉妒恨了. "下午的四.五点钟,北欧人 ...

  6. 使用eclipse创建在myeclipse中运行的web工程

    今天在跟随慕课网学习java时,遇到课程中老师使用Myeclipse,我用的是eclipse,那么就使用eclipse创建在Myeclipse项目 参考: 如何在Eclipse配置Tomcat服务器 ...

  7. Linux Program

    vhost : web.myftp.com storage.myftp.com ...... not vhost : storage.myftp.com eg : top eg : htop eg : ...

  8. IOS打开其他应用、以及被其他应用打开

    1.打开其他应用 appURLStr = "cwork://app_id?title=xxx&content=xxx" [[UIApplication sharedAppl ...

  9. MySQL表的增删改查和列的修改(二)

    一.使用Like模糊查找搜索前缀为以“exam_”开头的表名 show tables like 'exam_%' ; 语句结束符号是:也是用\G来表示 二.MySQL表的CRUD 2.1 创建表: C ...

  10. SecureCRT下的串口无法输入

    用串口配置交换机的时候,出现的问题: 用secureCRT建了一个串口COM1后,连接上开发板后,可以正确接受和显示串口的输出,但是按键输入无效. 解决方法: Session Options -> ...