用BAPI_ACC_DOCUMENT_POST过账生成凭证
根据前台需要输入参数,在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过账生成凭证的更多相关文章
- 【ABAP系列】SAP ABAP 资产类BAPI过账 BAPI_ACC_DOCUMENT_POST
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP 资产类BAPI ...
- 关于BAPI_ACC_DOCUMENT_POST解读
BAPI_ACC_DOCUMENT_POST是SAP ERP提供生成会计凭证的标准BAPI,这个BAPI可以用到多种场景生成会计凭证,实际项目中一般情况下更多的是生成应收和应付的会计凭证,分别对应客户 ...
- NC凭证接口(Java发送流和处理返回结果)
问题描述: 金融行业在系统模块分为财务和业务两个系统,我公司是负责业务模块系统,NC公司负责财务系统.但是财务有时候需要生成凭证,这时候就涉及业务模块了,我方就需要写NC凭证接口.这时候就需要三方交互 ...
- 用友二次开发之科脉TOT3凭证接口
按客户的要求,根据科脉导出的数据,开发一个工具,将凭证导入T3 这个科目导出的凭证格式. 选择账套登陆,你没看错,这个是我开发的登陆界面. 选择接口文件. 软件自动进数据分类,你可以看到数据了.但只是 ...
- 收货MIGO
FUNCTION zrfc_mm003. *"---------------------------------------------------------------------- * ...
- BAPI_GOODSMVT_CREATE 移动类型201 CODE = '03' 代码
DATA: MAT_DOC LIKE BAPI2017_GM_HEAD_RET-MAT_DOC. "物料凭证编号 DATA: GMHEAD LIKE BAPI2017_GM_H ...
- BAPI_GOODSMVT_CREATE 移动类型311 CODE = '04' 代码
DATA: MAT_DOC LIKE BAPI2017_GM_HEAD_RET-MAT_DOC. "物料凭证编号 DATA: GMHEAD LIKE BAPI2017_GM_H ...
- GL_总账完整会计周期业务(流程)
2014-06-02 BaoXinjian
- F-02 创建财务凭证BAPI
**.获取抬头参数, documentheader **.项目参数 accountgl = lt_acgl"G/L account item accountreceivable = lt_a ...
随机推荐
- windows下cocos2d-x工程结构讲解
这是我们新建好的工程,稍微解释一下我们开发windows的cocos应用所用到的几个文件夹的作用 Classes文件夹,存放游戏代码中的类的源码,当然我们放在别的地方也可以,只要配置好依赖关系就行了 ...
- (转)isolation forest进行异常点检测
原文链接:https://www.cnblogs.com/gczr/p/9156971.html 一.简介 孤立森林(Isolation Forest)是另外一种高效的异常检测算法,它和随机森林类似, ...
- python Windows环境下文件路径问题
转自:http://blog.sina.com.cn/s/blog_5ee7254801013zu7.html 在python程序里面我们经常需要对文件进行操作,Windows下的文件目录路径使用反斜 ...
- idea中tomcat乱码
idea中tomcat乱码 解决方案: a. file - settings - 搜File Encodings,改为utf-8 b.打开idea工作目录bin,在idea64.exe.vmoptio ...
- 用XHR简单封装一个axios
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- hadoop访问50070
http://ip:50070 注意id必须是namenode节点才能访问,datanode不能访问
- Linux日志中出现大量dhclient mesage浅析
最近检查发现一台Linux服务器,发现其日志里面有大量下面信息,其中部分信息做了脱敏处理.其中一个地址A(192.168.AAA.AAA) 为DNS服务器地址,地址B(192.168.BBB.BBB) ...
- linux下挂载iso镜像文件
linux挂载iso镜像可以分为两种,直接挂载镜像和上传镜像文件至服务器进行挂载 一.虚拟机镜像挂载 测试时使用虚拟机,此时可以直接在虚拟机的设置中将镜像文件直接选择并进行挂载,无需上传至虚拟机服务器 ...
- MySQL 57安装部署(Zip版)(Windows版)
1. 在<MYSQL>的根目录下新建一个my.ini写入以下内容 [mysqld] port = 3306 basedir=D:\mysql\mysql-5.7.22-winx64 # M ...
- Java学习笔记(7)---流(Stream),文件(File)
1.Stream流 a.定义: Java.io 包几乎包含了所有操作输入.输出需要的类.所有这些流类代表了输入源和输出目标. Java.io 包中的流支持很多种格式,比如:基本类型.对象.本地化字符集 ...