引自:http://blog.csdn.net/champaignwolf/article/details/51422329

FUNCTION zincominginvoice_park.

*"----------------------------------------------------------------------
*"*"Local interface:
*"  EXPORTING
*"     VALUE(CODE) TYPE  CHAR01
*"     VALUE(MESSAGE) TYPE  CHAR200
*"  TABLES
*"      INPUT STRUCTURE  ZFC_INCOMINGINVOICE_PARK_INPUT OPTIONAL
*"----------------------------------------------------------------------

DATA: vp_eind(1),
        ls_headerdata       LIKE bapi_incinv_create_header,
        lt_itemdata         LIKE TABLE OF bapi_incinv_create_item,
        ls_itemdata         LIKE bapi_incinv_create_item,
        lt_materialdata     LIKE TABLE OF bapi_incinv_create_material,
        ls_materialdata     LIKE bapi_incinv_create_material,
        lt_taxdata          LIKE TABLE OF bapi_incinv_create_tax,
        ls_taxdata          LIKE bapi_incinv_create_tax,
        lt_return           LIKE TABLE OF bapiret2,
        ls_return           LIKE bapiret2,
        lv_invoicedocnumber LIKE bapi_incinv_fld-inv_doc_no,
        lv_fiscalyear       LIKE bapi_incinv_fld-fisc_year.

DATA:lv_mwskz LIKE ekpo-mwskz.
  DATA:lv_rblgp TYPE rblgp.
*1/3 invoice_ind='X' db_cr_ind='S' (抬头),  2/4 invoice_ind='' db_cr_ind='H'  (外部物料相关项目)
*1/2 de_cre_ind =''   ,  3/4 de_cre_ind='X'   (po采购订单相关项目)

* BAPI赋值
  CLEAR input.
  READ TABLE input INDEX 1.
  IF sy-subrc EQ 0.
    ls_headerdata-invoice_ind  = 'X'." sp_head-xrech.    "发票标志
*  ls_headerdata-doc_type     = 'RE'."sp_head-blart.
    ls_headerdata-doc_date     = sy-datum."sp_head-bldat.
    ls_headerdata-pstng_date   = sy-datum. "sp_head-budat.
    ls_headerdata-bline_date   = sy-datum. "sp_head-zfbdt.    "基线日期/付款计算的起始日期

ls_headerdata-comp_code    = '6100'."sp_head-bukrs.
    SELECT SINGLE
           waers
           INTO ls_headerdata-currency
           FROM ekko
           WHERE ebeln = input-ebeln.

*    ls_headerdata-gross_amount = '24'."sp_head-rmwwr.    "总金额
*  ls_headerdata-del_costs    = sp_head-beznk.    "未计划的交货费
*  ls_headerdata-pmnttrms     = sp_head-zterm.    "付款条件
*  ls_headerdata-alloc_nmbr   = sp_head-zuonr.    "分配编号/外部发票号码
*  ls_headerdata-diff_inv     = sp_head-lifnr.    "出票方/供应商
*  ls_headerdata-ref_doc_no   = sp_head-xblnr.
    ls_headerdata-header_txt   = input-bktxt."'123'."sp_head-bktxt.
    ls_headerdata-item_text    = input-sgtxt."'456'."sp_head-sgtxt.
  ENDIF.

CLEAR lv_rblgp.
  LOOP AT input.
    lv_rblgp = lv_rblgp + 1.
    CLEAR lv_mwskz.
    SELECT SINGLE
           mwskz
           meins
           INTO (lv_mwskz,ls_itemdata-po_unit)
           FROM ekpo
           WHERE ebeln = input-ebeln
             AND ebelp = input-ebelp.

ls_headerdata-gross_amount = ls_headerdata-gross_amount + input-wrbtr.

ls_itemdata-invoice_doc_item = lv_rblgp."ls_poitem-buzei.   "发票行项目号
    ls_itemdata-po_number        = input-ebeln."'4500038014'."ls_poitem-ebeln.
    ls_itemdata-po_item          = input-ebelp."'10'."ls_poitem-ebelp.

SELECT SINGLE
           belnr
           gjahr
           buzei
           INTO (ls_itemdata-ref_doc,ls_itemdata-ref_doc_year,ls_itemdata-ref_doc_it  )
           FROM ekbe
           WHERE ebeln = input-ebeln
             AND ebelp = input-ebelp
             AND belnr = input-mblnr.
*    ls_itemdata-ref_doc          = '5000188866'."ls_poitem-lfbnr.
*    ls_itemdata-ref_doc_year     = '2016'."ls_poitem-lfgja.
*    ls_itemdata-ref_doc_it       = '1'."ls_poitem-lfpos.

ls_itemdata-item_amount      = input-wrbtr."'24'."ls_poitem-wrbtr.
    ls_itemdata-quantity         = input-menge."'2'."ls_poitem-menge.
*    ls_itemdata-po_unit          = 'EA'."ls_poitem-meins.
    ls_itemdata-tax_code         = lv_mwskz."ls_poitem-mwskz.

APPEND ls_itemdata TO lt_itemdata.
    CLEAR: ls_itemdata.

"  LOOP AT tp_baitem INTO ls_baitem.
    ls_materialdata-invoice_doc_item = lv_rblgp."ls_baitem-buzei.
    ls_materialdata-material         = input-matnr."'VBJHH05000000000'."ls_baitem-matnr.
    ls_materialdata-val_area         = '6100'."ls_baitem-bwkey.    "评估范围/工厂
    ls_materialdata-valuation_type   = '6100'."ls_baitem-bwtar.    "评估类型
    ls_materialdata-db_cr_ind        = 'S'."ls_baitem-shkzg.    "借方/贷方标识
    ls_materialdata-item_amount      = '0'."ls_baitem-wrbtr.
    ls_materialdata-quantity         = input-menge."ls_baitem-menge.
    SELECT SINGLE
           meins
           INTO ls_materialdata-base_uom
           FROM mara
           WHERE matnr = input-matnr.
*    ls_materialdata-base_uom         = 'EA'."ls_baitem-meins.
    ls_materialdata-tax_code         = lv_mwskz."ls_baitem-mwskz.
    APPEND ls_materialdata TO lt_materialdata.
    CLEAR: ls_materialdata.

ls_taxdata-tax_code   = lv_mwskz."ls_taitem-mwskz.
    "    ls_taxdata-tax_amount = ''."ls_taitem-wrbtr.
    APPEND ls_taxdata TO lt_taxdata.
    CLEAR: ls_taxdata.
  ENDLOOP.

CALL FUNCTION 'BAPI_INCOMINGINVOICE_PARK'
    EXPORTING
      headerdata          = ls_headerdata
*     ADDRESSDATA         =
    IMPORTING
      invoicedocnumber    = lv_invoicedocnumber
      fiscalyear          = lv_fiscalyear
    TABLES
      itemdata            = lt_itemdata
*     ACCOUNTINGDATA      =
*     GLACCOUNTDATA       =
      materialdata        = lt_materialdata
      taxdata             = lt_taxdata
*     WITHTAXDATA         =
*     VENDORITEMSPLITDATA =
      return              = lt_return.

IF lv_invoicedocnumber IS INITIAL OR lv_fiscalyear IS INITIAL.
    vp_eind = 'X'.
  ENDIF.

IF vp_eind = 'X'.
    CALL FUNCTION 'BAPI_TRANSACTION_ROLLBACK'.

code = '1'.
    LOOP AT lt_return INTO ls_return WHERE type = 'E'.
      IF message IS INITIAL.
        message = ls_return-message.
      ELSE.
        CONCATENATE message ';' ls_return-message INTO message.
      ENDIF.

CONCATENATE '预制发票失败:' message INTO message.
    ENDLOOP.

ELSE.
    CALL FUNCTION 'BAPI_TRANSACTION_COMMIT'
      EXPORTING
        wait = 'X'.
    code = '0'.
    CONCATENATE '预制发票成功,发票号:' lv_invoicedocnumber '发票年度:' lv_fiscalyear INTO message.
  ENDIF.

ENDFUNCTION.

函数使用五:MIR7 发票预制 BAPI_INCOMINGINVOICE_PARK的更多相关文章

  1. Python 进程线程协程 GIL 闭包 与高阶函数(五)

    Python 进程线程协程 GIL 闭包 与高阶函数(五) 1 GIL线程全局锁 ​ 线程全局锁(Global Interpreter Lock),即Python为了保证线程安全而采取的独立线程运行的 ...

  2. resize函数有五种插值算法

    转自http://blog.csdn.net/fengbingchun/article/details/17335477 最新版OpenCV2.4.7中,cv::resize函数有五种插值算法:最近邻 ...

  3. 第196天:js---调用函数的五种方式

    一.普通方式 /*普通模式*/ // 声明一个函数,并调用 function func() { console.log("Hello World"); } func(); 二.函数 ...

  4. matlab自定义函数的五种表示(前2种重点)

    1.命令文件/函数文件+函数文件:多个M文件 2.函数文件+子函数:一个M文件 3. inline:无需M文件 4.符号表达式+subs方式:无需M文件 5.字符串+subs方式:无需M文件 第一种: ...

  5. C# 中奇妙的函数–6. 五个序列聚合运算(Sum, Average, Min, Max,Aggregate)

    今天,我们将着眼于五个用于序列的聚合运算.很多时候当我们在对序列进行操作时,我们想要做基于这些序列执行某种汇总然后,计算结果. Enumerable 静态类的LINQ扩展方法可以做到这一点 .就像之前 ...

  6. python函数(五)

    函数 1.函数基本语法及特性 背景提要 现在老板让你写一个监控程序,监控服务器的系统状况,当cpu\memory\disk等指标的使用量超过阀值时即发邮件报警, 你掏空了所有的知识量,写出了以下代码 ...

  7. Scala 函数(五)

    函数是一组一起执行一个任务的语句. 您可以把代码划分到不同的函数中.如何划分代码到不同的函数中是由您来决定的,但在逻辑上,划分通常是根据每个函数执行一个特定的任务来进行的. Scala 有函数和方法, ...

  8. javascript调用Flash里对象的方法(函数)搞了五个小时。

    搞了几个小时后,才发现,之前走的路是错的. 今天在Firefox浏览器上测试一个javascript调用Flash中的一个对象的方法时遇到问题了, 一搞就整整搞了一个下午. 我记得之前我用Flash8 ...

  9. python第十四课--排序及自定义函数之自定义函数(案例五)

    演示函数的定义和使用细节: 默认参数:#在设计自定义函数的时候,就存在一个默认值,就算在调用的时候不显示的传入实参,也不会报错.#会用默认值来代替参与后期的运算 def m1(name='张三',ag ...

随机推荐

  1. AtomicReference实现单例模式

    CAS是项乐观锁技术,当多个线程尝试使用CAS同时更新同一个变量时,只有其中一个线程能更新变量的值,而其它线程都失败,失败的线程并不会被挂起,而是被告知这次竞争中失败,并可以再次尝试. 乐观锁的一种实 ...

  2. react-redux的mapStateToProps可取到state值但不会注入props

    一.问题描述 想通过react-redux和redux实现react组件之间的通信,reducer.action.store都编写正确,mapDispatchToProps也能正确传值.唯独mapSt ...

  3. JSONObject的parseArray方法作用。

    该方法将字符串数据转换成集合对象. String dep_tree = JedisUtils.getInstance().get(CacheConstant.DEP_TREE, user.getId( ...

  4. 启动tomcat 报错:Neither the JAVA_HOME nor the JRE_HOME environment variable is defined

    [root@localhost META-INF]# systemctl start tomcat Job for tomcat.service failed because the control ...

  5. 详细解说Tomcat 设置虚拟路径的几种方法及为什么设置虚拟路径

    说明:此次使用的是Tomcat 7.0 很多朋友都会很疑惑,既然我们都知道在Tomcat服务器上部署项目只要将项目打包,然后放到webapps目录下就可以了,为什么还需要配置虚拟路径?的确,把项目放到 ...

  6. L2-019. 悄悄关注

    说真的,看了一些L2题明白多学点库函数是多么重要!!!! 会map这题直接水过,map用法不解释自己学,代码如下: #include<bits/stdc++.h> using namesp ...

  7. Trailing Zeroes (I) LightOJ - 1028

    题意就是给你一个数让你找它的正因子个数(包括自身,不包括1),这个地方用到一个公式,如果不用的话按正常思路来写会TL什么的反正就是不容易写对. 求任意一个大于1的整数的正因子个数 首先任意一个数n,n ...

  8. leecode第十六题(最接近的三数之和)

    class Solution { public: void quick_order(vector<int>& num, int star, int en)//快排 { int st ...

  9. HTML 标记 1

    1. 文件结构 <html>                   ----------------------开始 <head>          -------------- ...

  10. Spring Cloud 入门教程(二): 配置管理

    使用Config Server,您可以在所有环境中管理应用程序的外部属性.客户端和服务器上的概念映射与Spring Environment和PropertySource抽象相同,因此它们与Spring ...