DATA: E_ORDER_HEADER_IN  LIKE  BAPISDHD1 OCCURS 0 WITH HEADER LINE,
          E_ORDER_PARTNERS   LIKE  BAPIPARNR OCCURS 0 WITH HEADER LINE,
          E_ORDER_ITEMS_IN   LIKE  BAPISDITM OCCURS 0 WITH HEADER LINE,
          E_ORDER_BAPISCHDL  LIKE BAPISCHDL OCCURS 0 WITH HEADER LINE,
          E_AUART            LIKE  VBAK-AUART ,
          E_KUNNR            LIKE  VBAK-KUNNR,
          CNT TYPE I,
          E_MENGE TYPE DZMENG.
  DATA: lt_order_text TYPE TABLE OF bapisdtext.
  DATA: ls_order_conditions_in  TYPE bapicond.
  DATA  lt_order_conditions_in  TYPE TABLE OF bapicond.
  DATA: e_order_text  TYPE bapisdtext.
  DATA : W_KNA1 LIKE KNA1 ,
         W_ADR6 LIKE ADR6 .
  data: ls_type type ZSCS004-PURAUDITFLAG.
  data: ls_knumv type vbak-knumv.
  DATA : W_NAME LIKE KNA1-NAME1.
  data: ls_inco1 type KNVV-INCO1,
      ls_zterm type KNVV-ZTERM.
  data: it_konv like KONV OCCURS 0 WITH HEADER LINE.  "选择条目
  data: ls_konv type KONV.
  DATA : I_BAPISDTEXT  TYPE STANDARD TABLE OF BAPISDTEXT.
  DATA : l_external TYPE BAPI2093_RES_KEY-RESERV_NO.
  DATA : WA_BAPISDTEXT LIKE LINE OF I_BAPISDTEXT.
  data:ls_sale type ZSD_SALE_TEST.
  data: ls_first type KUNNR,
        ls_last type KUNNR.

loop AT ZSD_SALE_TEST INTO ls_sale.

"add_text 抬头文本
    e_order_text-doc_number = SALESDOCUMENT.
    e_order_text-itm_number = '000000'.
    e_order_text-text_id = '0001'.
    e_order_text-langu = 1.
    e_order_text-langu_iso = 'ZH'.
    e_order_text-format_col = '*'.
    e_order_text-text_line = ls_sale-text_line.
    e_order_text-function = '005'.
    APPEND e_order_text TO lt_order_text.

"add_text:
    e_order_text-doc_number = SALESDOCUMENT.
    e_order_text-itm_number = ls_sale-POSNR.
    e_order_text-text_id = '0002'.
    e_order_text-langu = 1.
    e_order_text-langu_iso = 'ZH'.
    e_order_text-format_col = '*'.
    e_order_text-text_line = ls_sale-ARKTX.
    e_order_text-function = '005'.
    APPEND e_order_text TO lt_order_text.
    clear e_order_text.

"add_partners 抬头文本
*    "客户代码之前加1位
*    CONCATENATE '1' ls_sale-FIRST_NAME into ls_first.
*    CONCATENATE '1' ls_sale-LAST_NAME into ls_last.
    ls_first = ls_sale-FIRST_NAME.
    ls_last = ls_sale-LAST_NAME.
    CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
          EXPORTING
            INPUT  = ls_first
          IMPORTING
            OUTPUT = ls_first.

CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
          EXPORTING
            INPUT  = ls_last
          IMPORTING
            OUTPUT = ls_last.

E_ORDER_PARTNERS-PARTN_ROLE = 'AG'.  "售达方
    E_ORDER_PARTNERS-PARTN_NUMB = ls_first.  "售达方代码
    APPEND E_ORDER_PARTNERS.

E_ORDER_PARTNERS-PARTN_ROLE = 'WE'.  "送达方
    E_ORDER_PARTNERS-PARTN_NUMB = ls_last.   "送达方代码
    APPEND E_ORDER_PARTNERS.

E_AUART = ls_sale-AUART.

E_ORDER_HEADER_IN-DOC_TYPE = E_AUART.              "订单类型
    E_ORDER_HEADER_IN-SALES_ORG = ls_sale-VKORG.               "销售组织
    E_ORDER_HEADER_IN-DISTR_CHAN = ls_sale-VTWEG.              "分销渠道
    E_ORDER_HEADER_IN-DIVISION = ls_sale-SPART.                "产品组
    E_ORDER_HEADER_IN-req_date_h = ls_sale-ETDAT.              "请求交货日期
    E_ORDER_HEADER_IN-ship_type = '01'.                 "装运类型
    E_ORDER_HEADER_IN-ship_cond = ls_sale-VSBED.                "装运条件
    E_ORDER_HEADER_IN-PURCH_NO_C  = ls_sale-BSTNK.       "客户采购订单编号

E_ORDER_ITEMS_IN-item_categ = ls_sale-PSTYV.               "项目类别
    E_ORDER_ITEMS_IN-plant = ls_sale-WERKS.                    "工厂
    E_ORDER_ITEMS_IN-store_loc = ls_sale-LGORT.                "库存地点

E_ORDER_ITEMS_IN-MATERIAL = ls_sale-MABNR.                 "物料
*    E_ORDER_ITEMS_IN-BATCH = ls_sale-CHARG.                     "批次
    E_ORDER_ITEMS_IN-TARGET_QTY = ls_sale-KWMENG.              "订单数量
    E_ORDER_ITEMS_IN-sales_unit = ls_sale-VRKME.               "单位
    E_ORDER_ITEMS_IN-ITM_NUMBER = ls_sale-POSNR.               "项目号
    E_ORDER_ITEMS_IN-DLV_PRIO = ls_sale-REQUESTYPE.            "交货优先权
*  E_ORDER_ITEMS_IN-PMNTTRMS = '0001'.
    select KNVV~INCO1 KNVV~ZTERM
    INTO (ls_inco1,ls_zterm)
    from KNVV
    where KUNNR = ls_first and
      VKORG = ls_sale-VKORG and
      VTWEG = ls_sale-VTWEG and
      SPART = ls_sale-SPART.
    endselect.

E_ORDER_ITEMS_IN-PMNTTRMS = ls_zterm.                          "付款条件
    E_ORDER_ITEMS_IN-INCOTERMS1 = ls_inco1.                         "国际贸易条件
    E_ORDER_BAPISCHDL-REQ_QTY = ls_sale-KWMENG.                "订单数量
    E_ORDER_BAPISCHDL-ITM_NUMBER = ls_sale-POSNR.              "项目号

*  **  add_conditions:
      ls_order_conditions_in-itm_number = ls_sale-POSNR.
      ls_order_conditions_in-cond_type  = 'ZPR2'.  "定价条件
      ls_order_conditions_in-cond_value = ls_sale-KBETR.  "价格
      ls_order_conditions_in-currency   = 'RMB'.  "货币或%
      ls_order_conditions_in-cond_unit  = ls_sale-VRKME.  "条件单位
    ls_order_conditions_in-cond_p_unt = ls_sale-KWMENG.  "条件定价单位

*     ls_order_conditions_in-cond_unit = 'Z37'.
*     ls_order_conditions_in-itm_number = POSNR.
*  **      IF ( t_create-auart = 'ZCR' ) OR ( t_create-auart = 'ZDR' ).
*  **        ls_order_conditions_in-cond_type = 'ZPR2'.
*  **      ELSE.
*  **        ls_order_conditions_in-cond_type = 'ZPR1'.
*  **      ENDIF.
*     ls_order_conditions_in-cond_value = 10.
      ls_order_conditions_in-cond_updat  = 'X'.  "价格更新标志
      APPEND ls_order_conditions_in TO lt_order_conditions_in.

CLEAR   WA_BAPISDTEXT.
    REFRESH I_BAPISDTEXT.

*  WA_BAPISDTEXT-TEXT_ID   = '0001'.
*  WA_BAPISDTEXT-LANGU     = SY-LANGU.
*  WA_BAPISDTEXT-TEXT_LINE = COMMENT.
*  APPEND WA_BAPISDTEXT TO I_BAPISDTEXT.
    APPEND E_ORDER_BAPISCHDL.
    APPEND E_ORDER_ITEMS_IN.
*    MODIFY zsd_sale_test from ls_sale.
    clear ls_sale.
  endloop.

****创建销售订单
*  CALL FUNCTION 'BAPI_SALESORDER_CREATEFROMDAT2'
*    EXPORTING
*      ORDER_HEADER_IN     = E_ORDER_HEADER_IN
*    IMPORTING
*      SALESDOCUMENT       = SALESDOCUMENT
*    TABLES
*      RETURN              = RETURN
*      ORDER_SCHEDULES_IN  = E_ORDER_BAPISCHDL
*      ORDER_ITEMS_IN      = E_ORDER_ITEMS_IN
*      ORDER_PARTNERS      = E_ORDER_PARTNERS
*      ORDER_CONDITIONS_IN = lt_order_conditions_in
*      ORDER_TEXT          = lt_order_text.

CALL FUNCTION 'SD_SALESDOCUMENT_CREATE'
      EXPORTING
        SALESDOCUMENT     = SALESDOCUMENT
        sales_header_in     = E_ORDER_HEADER_IN
*        logic_switch        = lv_logic_switch
      IMPORTING
        SALESDOCUMENT_EX       = SALESDOCUMENT
      TABLES
        return              = RETURN
        sales_items_in      = E_ORDER_ITEMS_IN
        sales_partners      = E_ORDER_PARTNERS
        sales_schedules_in  = E_ORDER_BAPISCHDL
        sales_conditions_in = lt_order_conditions_in
        sales_text          = lt_order_text.

SO BAPI SD_SALESDOCUMENT_CREATE的更多相关文章

  1. 创建SO bapi

    转自http://blog.sina.com.cn/s/blog_1647b3eff0102wi32.html 1.创建销售订单使用的BAPI BAPI_SALESORDER_CREATEFROMDA ...

  2. BAPI

    MM模块 1. BAPI_MATERIAL_SAVEDATA 创建物料主数据 注意参数EXTENSIONIN的使用,可以创建自定义字段 例如:WA_BAPI_TE_MARA-MATERIAL = IT ...

  3. BAPI LIST

    [转自 http://blog.csdn.net/minsenwu/article/details/8432081] 库存管理BAPI 库存: 1. BAPI_MATERIAL_AVAILABILIT ...

  4. SAP 各模块常用的BAPI

    MM模块 1. BAPI_MATERIAL_SAVEDATA 创建物料主数据 注意参数EXTENSIONIN的使用,可以创建自定义字段 例如:WA_BAPI_TE_MARA-MATERIAL = IT ...

  5. PP常用bapi

    PPCO0012 co01/CO02/CO03屏幕bapi  生产订单:显示/更改订单抬头数据 PPCO0001 开发应用程序: PP订单 PPCO0007 保存生产订单时退出 PPCO0001  A ...

  6. BAPI 调用相当于BAPI_TRANSACTION_COMMIT 的方法

    为什么.net调用SAP的BAPI接口需要调用BAPI_TRANSACTION_COMMIT呢?首先得明白BAPI_TRANSACTION_COMMIT这个BAPI的作用.它功劳很大,在SAP里面很多 ...

  7. idoc 和 bapi 和 rfc 之间的区别

        se37 写出来的叫function,其中可以远程调用的叫rfc,remote-enabled function,abap语法和输入输出参数就会有一些限制.bapi是sap做好的实现特定业务操 ...

  8. 业务对象和BAPI

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  9. [SAP ABAP开发技术总结]BAPI调用

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

随机推荐

  1. 测试数年来,我只提了几十个bug

    ---恢复内容开始--- 测试做了十来年,大大小小的项目产品已经记不清了,开发们在一如既往地改着改了无数遍的bug,测试也一如既往的提着提了无数遍的bug,那么今天笔者对以往的bug类型做一个简单的总 ...

  2. Linux 性能优化笔记:软中断(转载)

    进程的不可中断状态是系统的一种保护机制,可以保证硬件的交互过程不被意外打断. 所以,短时间的不可中断状态是很正常的. 但是,当进程长时间都处于不可中断状态时,你就得当心了.这时,你可以使用 dstat ...

  3. PowerDesigner 生成SQL Server 2005 注释脚本

    --生成数据表的注释EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=[%R%?[N]]%.q:COMMENT% , @l ...

  4. idea中使用JRebel插件

    首先 等待下载 点击Restart idea (重启idea) 然后等待idea 进行激活 记得勾选下面的那个复选框 激活url:http://139.199.89.239:1008/88414687 ...

  5. 生产环境跑PHP动态程序

    Nginx + PHP5(FastCGI)生产环境跑PHP动态程序可超过“700次请求/秒”   我生产环境下的两台Nginx + PHP5(FastCGI)服务器,跑多个一般复杂的纯PHP动态程序, ...

  6. Java I/O 全面详解

    1.什么是IO Java中I/O操作主要是指使用Java进行输入,输出操作. Java所有的I/O机制都是基于数据流进行输入输出,这些数据流表示了字符或者字节数据的流动序列.Java的I/O流提供了读 ...

  7. Machine Learn in Action(K-近邻算法)

    使用K-近邻算法将某点[0.6, 0.6]划分到某个类(A, B)中. from numpy import * import operator def classify0(inX, dataSet, ...

  8. 树莓派设定笔记(Raspberry Pi 3 B+)

    树莓派默认用户名密码 pi / raspberry 一.启用root用户 设置root用户密码 sudo passwd root 开启root账户 sudo passwd --unlock root ...

  9. 【leetcode】341. Flatten Nested List Iterator

    题目如下: Given a nested list of integers, implement an iterator to flatten it. Each element is either a ...

  10. poj 1064 高精度 二分

    Cable master Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 32191 Accepted: 6888 Descrip ...