根据前台需要输入参数,在bapi里面传值,不同业务所需参数不同。

dome1:

"bapi结构赋值
    LOOP AT lt_item INTO lw_item.
      wa_documentheader-comp_code = lw_item-bukrs. "公司代码
      wa_documentheader-doc_date   = p_date.       "凭证日期
      wa_documentheader-pstng_date = p_date.       "过账日期
      wa_documentheader-doc_type = 'Z4'.
      wa_documentheader-username = sy-uname.
      wa_documentheader-fisc_year = p_date+0(4).
      wa_documentheader-header_txt = '合同税率计算过账'.
      wa_documentheader-fis_period = sy-datum+4(2).

CLEAR :wa_accountgl.
      lv_i = lv_i + 1.
      wa_accountgl-itemno_acc = lv_i.              "会计凭证行项目编号
      wa_accountgl-gl_account = '6051060000'.        "总分类帐帐目
      wa_accountgl-item_text = '合同税率计算过账'.
      wa_accountgl-profit_ctr = lw_item-prctr.     "利润中心
      APPEND wa_accountgl TO lt_accountgl.

CLEAR wa_currency_amount.
      wa_currency_amount-itemno_acc = lv_i.     "行项目编号
      wa_currency_amount-amt_doccur = lw_item-taxamount.  "金额
      wa_currency_amount-currency   = 'CNY'.
      APPEND wa_currency_amount TO lt_currency_amount.

CLEAR:wa_zbapi_acc01,wa_extension2.
      wa_zbapi_acc01-posnr = lv_i.
      wa_zbapi_acc01-xnegp = 'X'.               "反记账
      wa_zbapi_acc01-bschl = '40'.
      wa_extension2-structure = 'ZBAPI_ACC01'.
      wa_extension2-valuepart1 = wa_zbapi_acc01.
      APPEND wa_extension2 TO lt_extension2.

CLEAR :wa_accountgl.
      lv_i = lv_i + 1.
      wa_accountgl-itemno_acc = lv_i.           "会计凭证行项目编号
      wa_accountgl-gl_account = lw_item-acctcode.   "总分类帐帐目
      wa_accountgl-item_text = '合同税率计算过账'.
      wa_accountgl-profit_ctr = lw_item-prctr.    "利润中心
      APPEND wa_accountgl TO lt_accountgl.

CLEAR wa_currency_amount.
      wa_currency_amount-itemno_acc = lv_i.    "行项目编号
      wa_currency_amount-amt_doccur = - lw_item-taxamount.  "金额
      wa_currency_amount-currency   = 'CNY'.
      APPEND wa_currency_amount TO lt_currency_amount.

CLEAR:wa_zbapi_acc01,wa_extension2.
      wa_zbapi_acc01-posnr = lv_i.
      wa_zbapi_acc01-bschl = '50'.
      wa_extension2-structure = 'ZBAPI_ACC01'.
      wa_extension2-valuepart1 = wa_zbapi_acc01.
      APPEND wa_extension2 TO lt_extension2.

"财务凭证为999行,到900行时,进行财务凭证拆分;调用bapi生成凭证
      IF lv_i >= 999.
        CALL FUNCTION 'BAPI_ACC_DOCUMENT_POST'
          EXPORTING
            documentheader = wa_documentheader
          IMPORTING
            obj_type       = lv_obj_type
            obj_key        = lv_obj_key
            obj_sys        = lv_obj_sys
          TABLES
            accountgl      = lt_accountgl
            currencyamount = lt_currency_amount
            return         = lt_return
            extension2     = lt_extension2.

CLEAR wa_return.
        READ TABLE lt_return INTO wa_return WITH KEY type = 'E'.
        IF sy-subrc = 0.
          CALL FUNCTION 'BAPI_TRANSACTION_ROLLBACK'. "失败
          LOOP AT lt_return INTO wa_return WHERE type = 'E'.
            ls_item-mesg = ls_item-mesg && '' && wa_return-message.
          ENDLOOP.
          ls_item-mesg =  '@0A@' && '过账失败:' && ls_item-mesg.
          ls_item-status = 'E'.
        ELSE.

CALL FUNCTION 'BAPI_TRANSACTION_COMMIT' "成功
            EXPORTING
              wait = 'X'.
          CONCATENATE '@08@' '过账成功' INTO ls_item-mesg.
          ls_item-status = 'S'.
ENDIF.

CLEAR : lv_i,wa_documentheader,lt_accountgl,wa_accountgl,lt_currency_amount,
            wa_currency_amount
,lt_extension2,lt_extension2[].

ENDIF.

ENDLOOP.

demo2:

LOOP AT  gt_item INTO gs_item.

AT NEW bukrs.
      
CLEAR:lv_i,wa_documentheader,lt_accountgl,wa_accountgl,lt_currency_amount,
      wa_currency_amount
,lt_extension2,lt_extension2[].
      wa_documentheader
-comp_code = gs_item-bukrs.
      
READ TABLE gt_item INTO gs_item INDEX sy-tabix.
      wa_documentheader
-doc_date   = p_budat.     "凭证日期
      wa_documentheader
-pstng_date = p_budat.     "过账日期
      wa_documentheader
-doc_type = 'SA'.
      wa_documentheader
-username = sy-uname.
      wa_documentheader
-header_txt = '调整折旧费用分摊'.
    
ENDAT.

IF gs_item-mes IS INITIAL.
      
CLEAR :wa_accountgl.
      lv_i 
= lv_i + 1.
      wa_accountgl
-itemno_acc = lv_i.                "会计凭证行项目编号
      wa_accountgl
-gl_account = gs_item-ktnafg.      "总分类帐帐目
      wa_accountgl
-costcenter = gs_item-kostl.       "成本中心
      wa_accountgl
-item_text = '调整折旧费用分摊'.
      wa_accountgl
-profit_ctr = gs_item-bukrs.       "利润中心
      
APPEND wa_accountgl TO lt_accountgl.

CLEAR wa_currency_amount.
      wa_currency_amount
-itemno_acc = lv_i.             "行项目编号
      wa_currency_amount
-amt_doccur = - gs_item-nafaz.  "金额
      wa_currency_amount
-currency   = 'CNY'.
      
APPEND wa_currency_amount TO lt_currency_amount.

CLEAR :wa_accountgl.
      lv_i 
= lv_i + 1.
      wa_accountgl
-itemno_acc = lv_i.                "会计凭证行项目编号
      wa_accountgl
-gl_account = gs_item-hkont.       "总分类帐帐目
      wa_accountgl
-costcenter = gs_item-kostl1.      "成本中心
      wa_accountgl
-profit_ctr = gs_item-bukrs.       "利润中心
      wa_accountgl
-item_text = '调整折旧费用分摊'.
      
APPEND wa_accountgl TO lt_accountgl.

CLEAR wa_currency_amount.
      wa_currency_amount
-itemno_acc = lv_i.           "行项目编号
      wa_currency_amount
-amt_doccur = gs_item-nafaz.  "金额
      wa_currency_amount
-currency   = 'CNY'.
      
APPEND wa_currency_amount TO lt_currency_amount.

CLEAR:wa_zbapi_acc01,wa_extension2.
      wa_zbapi_acc01
-posnr = lv_i.
      
IF gs_item-nafaz LT 0.
        wa_zbapi_acc01
-xnegp = 'X'.                   "反记账
      
ENDIF.
      wa_extension2
-structure = 'ZBAPI_ACC01'.
      wa_extension2
-valuepart1 = wa_zbapi_acc01.
      
APPEND wa_extension2 TO lt_extension2.
    
ENDIF.

AT END OF bukrs.
      
"调用bapi生成凭证
      
CALL FUNCTION 'BAPI_ACC_DOCUMENT_POST'
        
EXPORTING
          documentheader 
= wa_documentheader
        
IMPORTING
          obj_type       
= lv_obj_type
          obj_key        
= lv_obj_key
          obj_sys        
= lv_obj_sys
        
TABLES
          accountgl      
= lt_accountgl
          currencyamount 
= lt_currency_amount
          
return         = lt_return
          extension2     
= lt_extension2.

LOOP AT gt_anlp1 ASSIGNING   <f1> WHERE box EQ 'X' AND mes EQ space.
        
CLEAR wa_return.
        
READ TABLE lt_return INTO wa_return WITH KEY type = 'E'.
        
IF sy-subrc = 0.
          
CONCATENATE '@0A@' '调整失败:' wa_return-message INTO <f1>-mes.
          
CONCATENATE 'E' gs_anlp-sta INTO <f1>-sta.
        
ELSE.
          
CONCATENATE '@08@' '科目调整成功' lv_obj_key+0(10) INTO <f1>-mes.
          
CONCATENATE 'S' '' INTO <f1>-sta.
        
ENDIF.
        <f1>
-pname = sy-uname.
        <f1>
-pdate = sy-datum.
        <f1>
-ptime = sy-uzeit.
        <f1>
-belnr_t = lv_obj_key+0(10).
        <f1>
-peraf = p_peraf.
      
ENDLOOP.

PERFORM frm_save_data.

CALL FUNCTION 'BAPI_TRANSACTION_COMMIT'
        
EXPORTING
          
wait = 'X'.
    
ENDAT.
  
ENDLOOP.

注意:bapi结束需要

CALL FUNCTION 'BAPI_TRANSACTION_COMMIT''.

CALL FUNCTION 'BAPI_TRANSACTION_ROLLBACK'.

每生成一个凭证就保存。

用BAPI_ACC_DOCUMENT_POST过账生成凭证的更多相关文章

  1. 【ABAP系列】SAP ABAP 资产类BAPI过账 BAPI_ACC_DOCUMENT_POST

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP 资产类BAPI ...

  2. 关于BAPI_ACC_DOCUMENT_POST解读

    BAPI_ACC_DOCUMENT_POST是SAP ERP提供生成会计凭证的标准BAPI,这个BAPI可以用到多种场景生成会计凭证,实际项目中一般情况下更多的是生成应收和应付的会计凭证,分别对应客户 ...

  3. NC凭证接口(Java发送流和处理返回结果)

    问题描述: 金融行业在系统模块分为财务和业务两个系统,我公司是负责业务模块系统,NC公司负责财务系统.但是财务有时候需要生成凭证,这时候就涉及业务模块了,我方就需要写NC凭证接口.这时候就需要三方交互 ...

  4. 用友二次开发之科脉TOT3凭证接口

    按客户的要求,根据科脉导出的数据,开发一个工具,将凭证导入T3 这个科目导出的凭证格式. 选择账套登陆,你没看错,这个是我开发的登陆界面. 选择接口文件. 软件自动进数据分类,你可以看到数据了.但只是 ...

  5. 收货MIGO

    FUNCTION zrfc_mm003. *"---------------------------------------------------------------------- * ...

  6. BAPI_GOODSMVT_CREATE 移动类型201 CODE = '03' 代码

    DATA: MAT_DOC LIKE BAPI2017_GM_HEAD_RET-MAT_DOC.      "物料凭证编号   DATA: GMHEAD LIKE BAPI2017_GM_H ...

  7. BAPI_GOODSMVT_CREATE 移动类型311 CODE = '04' 代码

    DATA: MAT_DOC LIKE BAPI2017_GM_HEAD_RET-MAT_DOC.      "物料凭证编号   DATA: GMHEAD LIKE BAPI2017_GM_H ...

  8. GL_总账完整会计周期业务(流程)

    2014-06-02 BaoXinjian

  9. F-02 创建财务凭证BAPI

    **.获取抬头参数, documentheader **.项目参数 accountgl = lt_acgl"G/L account item accountreceivable = lt_a ...

随机推荐

  1. vsto 检测是否在编辑状态或者光标闪动

    object m = Type.Missing; const int MENU_ITEM_TYPE = 1; const int NEW_MENU = 18; CommandBarControl oN ...

  2. easyui-datagrid 使用笔记

    1.清空所有行和所有列 $('#dgJGQuery').datagrid({ columns: [], url: '', data: [] }); 2.采用 datagrid-groupview 分组 ...

  3. WGS84、WebMercator、GCJ02和BD09坐标系简介与转换

    WGS84(GPS): 地心坐标系,空间直角坐标系,原点与地球质心重合,为GPS采用的坐标系,也是目前广泛使用的GPS全球卫星定位系统使用的坐标系. 通过GPS可以直接获取WGS84下的坐标(B,L, ...

  4. 「SAP技术」已启用质检物料创建PO时候'STOCK TYPE'没有默认为X?

    「SAP技术」 SAP MM 已启用质检物料创建PO时候'STOCK TYPE'没有默认为X? Part I:SAP 标准行为 1, 物料11002335, QM视图里 01 inspection t ...

  5. SAP记账期间变式

        记帐期间变式能够控制每个公司代码中打开的记账期间,包括正常记账期间和特别记账期间.可以为企业组织架构中的每个公司代码定义一个归其单独使用的记账期间变式.      记账期间变式独立于会计年度变 ...

  6. nmap的简单使用

    主机探测 1.扫描单个主机 nmap 192.168.1.2 2.扫描整个子网 nmap 192.168.1.1/24 3.扫描多个目标 nmap 192.168.1.1 192.168.1.1.5 ...

  7. OC-AVAudioSession的知识小记

    参考文章:https://www.cnblogs.com/junhuawang/p/7920989.html 音频输出作为硬件资源,对于iOS系统来说是唯一的,那么要如何协调和各个App之间对这个稀缺 ...

  8. jdbc大略

    一.概述JDBC JDBC从物理结构上说就是Java语言访问数据库的一套接口集合. 从本质上来说就是调用者(程序员)和实现者(数据库厂商)之间的协议. JDBC API: 使得开发人员可以使用纯Jav ...

  9. vue的类element的input类型组件封装

    前提:题主之前只是随意的封装,项目统一ui,然后只实现了父组件拿子组件值,没有实现父组件修改子组件的值,仔细看了文档才知道用model的作用,直接上代码 Vue.component("bas ...

  10. SSH远程管理

    目录 SSH远程管理 ssh功能 SSH相关命令 Xshell连接不上虚拟机 scp命令 SSH验证方式 优化 免交互expect[扩展] 免交互sshpass[扩展] 简易跳板机 小结 SSH远程管 ...