[abap] 应收账款台账

*&------------------------------------------------------------------
*& Program name: ZRFICO_RECEIVABLE
*& T-Code:  (XXXX)
*& Porgram Type: Report
*& Description: SOPO计划表
*&------------------------------------------------------------------
*& Author:  lipu
*& Date:    2011.05.16
*&------------------------------------------------------------------
*& Funciton Desc:
*&  应收账款台账
*&  显示结果:
*& 逻辑说明:*  1) 交货单数据LIKP、LIPS作为主数据:交货单号、行项目、物料号、交货数量、交货单创建日期、物料组、库位、批次
*&            2) 根据物料号,判断产品技术 (TN/FFS) 、厚度(1.0t/0.6t);
*&                根据交货单客户号,从KNA1——>客户名称;抓取VA03-抬头文本:二级客户长文本
*&            3) 物料描述——产品类型、厚度、工艺PS/BS、
*&            4) 预收款日期计算: 交货单创建日期 +  预收款条件设置日期 ; 另设置一列“人工编辑预收款日期”;
*&            5) 净价、净价单位抓取SO订单,金额 = 交货数量 * 净价 / 净价单位 ;
*&            6) 交货数量根据生产BOM来折算,Q-panel、CELL、GLASS
*&         *   7) SO单价为USD,则计算美元金额; 为RMB,考虑增值税金额;
*&            8) VBRP:抓取形势发票号(发票类型F8)、系统发票号(F2)、系统发票日期,
*&            9) 判断预收款日期是否超过当前日期;
*&         * 10)是否付款; 查询清账表BSAD、清账创建时间
*&         *  11) 根据SO订单号、行项目查找客户PO号 : VBKD-BSTKD
*&           12) 根据系统发票(F2),抓取会计凭证号、本位币金额;
*&         *  13) 抓取VBAK订单类型,描述-表TVAKT
*&           14) 查物料底层物料中是否有物料组为001的物料,判断是否外购
*&-------------------------------------------------------------------
*& Modification Log:
*& Version   Date        Author       DESCRIPTION     CHANGE REQUEST
*& -------- ----------  -----------  -------------  -----------------
*& 000      2011.05.16    lipu       Initial release

REPORT  ZRFICO_RECEIVABLE.
*-----------------      TABLES      ----------------------------*
TYPE-POOLS: slis.
TABLES:ZTFICO_YSZK,LIKP, LIPS , VBAK , VBAP .

*-----------------     VARIANTS     ----------------------------*
Data: name_1 LIKE ADRC-NAME1,   " 暂存供应商名称
      name_2 LIKE ADRC-NAME2.
" 长文本
DATA: gp_id LIKE thead-tdid,
      gp_nam LIKE thead-tdname,
      gp_obj LIKE thead-tdobject,
      gt_dline LIKE TABLE OF tline WITH HEADER LINE.

DATA: lv_language TYPE c.         " read_text 长文本语种
DATA : str_tmp TYPE string .

DATA: l_WEEK TYPE KWEEK .

DATA: VBELN_S TYPE VBELN.

DATA: l_MAKTX TYPE MAKTX,         " 物料描述中间变量
*      Head_text(20) TYPE C,         " 存储分割后的字符串,不能固定长度
*      Back_text(20) TYPE C.
       Head_text TYPE string,
       Back_text TYPE string,
       Back_01   TYPE string.
*BOM展开
data: gt_stpox like stpox occurs 0 with header line.  "
DATA:l_bom LIKE stko-bmeng.
DATA:l_stlnr LIKE mast-stlnr.

" user_command
DATA: u_command TYPE slis_formname VALUE 'USER_COMMAND'.
DATA: ok_code LIKE sy-ucomm.

*-----------------  INTERNAL TABLES ----------------------------*
* BOM反查"  以下内表缺一不可
DEFINE BOM_FIND.
data : begin of &1 occurs &2.     " 数量关系表
        include structure &3.
data : end of &1.
END-OF-DEFINITION.
   BOM_FIND: wultb    100   stpov,
             equicat  0     cscequi,
             kndcat   0     cscknd,
             matcat   0     cscmat,
             stdcat   0     cscstd,
             tplcat   0     csctpl.

* 销售订单SO
DATA : BEGIN OF it_so OCCURS 0,
       VBELV LIKE VBAP-VBELV,        " 销售订单号——实际取VBELN      便于与交货单号区分
       POSNV LIKE VBAP-POSNV,        " 销售订单项目——实际取POSNR
       WAERK LIKE VBAK-WAERK,         " 币别
       KUNNR LIKE VBAK-KUNNR,         " 客户号
       AUART LIKE VBAK-AUART,         " 订单类型
       BEZEI LIKE TVAKT-BEZEI,         " SO订单描述
*       ARKTX LIKE VBAP-ARKTX,         " 物料文本
       NETPR LIKE VBAP-NETPR,         " 净价( 每X个价值为Y )
       KPEIN LIKE VBAP-KPEIN,         " 定价单位
" 销售凭证 : 业务数据
       ZTERM LIKE VBKD-ZTERM,         " 付款方式代码
       ZTEXT1 LIKE T052U-TEXT1,       " 收付款方式自解释
       ZYSKD  TYPE ZYSKD,             " 预收款日
       ZDUE   TYPE ZTYWB,             " 是否超期
" 客户PO号
       BSTKD LIKE VBKD-BSTKD,         " 客户PO号
" 二级客户文本
       ZNAME2 TYPE ZNAME_KNA1,
       END OF it_so.

" 发票
DATA : BEGIN OF it_vbrp OCCURS 0,
       VGBEL  LIKE VBRP-VGBEL,        " 参考凭证-交货单号
       AUPOS  LIKE VBRP-AUPOS,        " 项目——交货单行项目
       VBELN  LIKE VBRP-VBELN,        " 开票凭证号
       POSNR  LIKE VBRP-POSNR,        " 项目
       FKART  LIKE VBRK-FKART,        "  发票类型
       FKDAT  LIKE VBRK-FKDAT,        " 发票日期(只要系统发票的)
       BLART  LIKE BKPF-BLART,        " 凭证类别
       AWKEY  LIKE BKPF-AWKEY,        " 参考关键字
       BELNR  LIKE BKPF-BELNR,        " 会计凭证号
       GJAHR  LIKE BKPF-GJAHR,        " 会计年度
       DMBTR  LIKE BSIS-DMBTR,        " 本位币金额
       SHKZG  LIKE BSIS-SHKZG,         " 借贷
       AUGBL  LIKE BSAD-AUGBL,        " 清账凭证号
       AUGDT  LIKE BSAD-AUGDT,        " 清账日期
       END OF it_vbrp.

DATA : it_T052 LIKE TABLE OF T052 WITH HEADER LINE.

"结果内表
DATA : it_out LIKE TABLE OF ZTFICO_YSZK WITH HEADER LINE.

" 中间内表
DATA: BEGIN OF it_lips OCCURS 0.
          INCLUDE STRUCTURE it_out.
DATA : AUART LIKE VBAK-AUART,    " 订单类型代码
       KPEIN TYPE KPEIN,          " 价格计量单位
      END OF it_lips.

DATA: it_lips_tmp LIKE TABLE OF it_lips WITH HEADER LINE.

*-----------------  macro & class ----------------------------*
DEFINE Lastday_month.
     CALL FUNCTION 'LAST_DAY_OF_MONTHS'
      EXPORTING
        day_in            = &1
      IMPORTING
        last_day_of_month = &2
      EXCEPTIONS
        day_in_no_date    = 1
        OTHERS            = 2.
END-OF-DEFINITION.
" ALV取数、显示、修改
CLASS lcl_report DEFINITION.
  PUBLIC SECTION.
    DATA : num TYPE I.
    TYPES : BEGIN OF type_data.
    TYPES : ZNUM TYPE I.
            INCLUDE STRUCTURE ZTFICO_YSZK.
    TYPES : SEL(01) TYPE C,
            ZYSKD_D TYPE ZYSKD,          " 人工维护预收款日期——修改前
            ZYSKD_S TYPE ZYSKD,          " 系统预收款日期——修改前
            END OF type_data.

    DATA: t_data TYPE STANDARD TABLE OF  type_data,
          gw_data TYPE type_data.
    METHODS:
      get_data,
      generate_output.
ENDCLASS.
DATA: lo_report TYPE REF TO lcl_report.   " 对象实例

*-----------------   SELECTION-SCREEN --------------------------*
SELECTION-SCREEN BEGIN OF BLOCK block1 WITH FRAME TITLE txt001.
SELECT-OPTIONS : p_WERKS  For  LIPS-WERKS  DEFAULT '2100'  to '2101',
                 s_ERDAT  for  LIPS-ERDAT .      " 创建日期

SELECT-OPTIONS : s_VBELN for LIPS-VBELN MODIF ID M1,                " 交货单
                 s_KUNNR for VBAK-KUNNR MODIF ID M1,                  " 售达方
                 s_VBELV FOR VBAP-VBELN MODIF ID M1,             " 订单号
                 s_WADAT FOR LIKP-WADAT_IST MODIF ID M1.         " 发货过账日期

SELECTION-SCREEN END OF BLOCK block1.

SELECTION-SCREEN BEGIN OF BLOCK b3 WITH FRAME TITLE title00.

PARAMETERS: p_xs TYPE c RADIOBUTTON GROUP rd DEFAULT 'X' USER-COMMAND rad_click2,    "显示
            p_js TYPE c RADIOBUTTON GROUP rd.                "计算
SELECTION-SCREEN SKIP 1.
PARAMETERS  p_dd TYPE c AS CHECKBOX MODIF ID M1 .   " 订单

SELECTION-SCREEN END OF BLOCK b3.

*-----------------   INITIALIZATION --------------------------——*
INITIALIZATION.
txt001 = '计算条件'.
title00 = '方式'.

s_ERDAT-sign = 'I'.
s_ERDAT-option = 'BT'.
s_ERDAT-low(06) =  sy-datum(06).
s_ERDAT-low+6(02) = '01'.
s_ERDAT-high = sy-datum.
 APPEND s_ERDAT.
* 创建 object
  CREATE OBJECT lo_report.

AT SELECTION-SCREEN OUTPUT.
  LOOP AT SCREEN.
      CASE screen-group1.
        WHEN 'M1'.
          if p_xs = 'X'.
             screen-active = '1'.
          else.
             screen-active = '0'.
          endif.
       endcase.
    MODIFY SCREEN.
   ENDLOOP.
*-----------------   START-OF-SELECTION --------------------------*
START-OF-SELECTION.
 if p_js = 'X'.    " 计算
" 交货单与SO数据
 PERFORM frm_get_LIPS.
 " 数据整理
 PERFORM frm_deal_data.
 " 保存数据

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ABAP是一种用于SAP系统开发的编程语言,它是一种高级语言,用于在SAP环境编写业务逻辑。ABAP语法是ABAP程序的书写规则,用于定义数据对象、变量、函数、方法等,以实现所需的功能。 ABAP的关键语法包括:数据类型定义、变量声明、语句结构、逻辑控制、循环结构、函数和方法定义等。通过这些语法,开发人员可以对数据进行处理、进行条件判断、循环操作以及定义自定义的功能模块。 ABAP语法的数据类型定义包括:整数、浮点数、字符串、日期、时间等。开发人员可以根据需要选择合适的数据类型来定义变量,并进行数据操作。变量声明可以通过关键字"DATA"或"FIELD-SYMBOLS"进行,这些关键字可以指定变量的数据类型、长度、可见性等属性。 在ABAP语法,还有一些重要的语句结构。例如,条件语句(IF...ELSE...ENDIF)用于根据条件选择不同的执行路径;循环语句(DO...END...WHILE)用于多次执行同一段代码;选择语句(CASE...WHEN...ENDCASE)用于根据不同的条件选择执行不同的代码块。 除此之外,ABAP语法还支持函数和方法的定义。函数是一段独立的代码块,可以接受输入参数并返回结果;方法则是与对象关联的代码块,用于对特定对象进行操作。 总之,ABAP语法是开发ABAP程序的基础,它提供了丰富的功能和灵活的语言结构,使得开发人员可以根据需要编写复杂的业务逻辑,并在SAP系统实现各种功能。通过熟悉ABAP语法,开发人员可以高效地进行开发工作,并实现各种业务需求。 ### 回答2: ABAP(Advanced Business Application Programming)是一种用于SAP系统的编程语言,它最初是为SAP R/3系统开发的。随着SAP系统的升级和改进,ABAP也进行了相应的发展,现今最新版本是ABAP S/4HANA。 ABAP S/4HANA是在SAP S/4HANA平台上使用的ABAP版本,它与传统的ABAP有一些重要的区别。首先,ABAP S/4HANA采用了新的数据模型,即S/4HANA物料管理(Material Ledger)和简化数据模型(SIMM)等,这些模型使用了新的内部数据技术,提高了数据处理性能和效率。 其次,ABAP S/4HANA引入了新的ABAP编程范式,例如ABAP CDS(Core Data Services)。ABAP CDS提供了一种声明式的编程方式,用于定义和处理数据模型、服务和视图。这种新的编程范式可以更好地支持SAP S/4HANA的新功能,并且使开发人员能够更轻松地创建和维护ABAP应用程序。 此外,ABAP S/4HANA还引入了更多的功能和特性,以优化开发和运行ABAP应用程序的性能。例如,它引入了ABAP Managed Database Procedures(AMDP),用于在数据库执行复杂的计算和处理。它还提供了更好的集成工具,如ABAP Test Cockpit和ABAP Development Tools,用于支持开发和测试过程。 总结而言,ABAP S/4HANA是ABAP语言在SAP S/4HANA平台上的最新版本,它引入了新的数据模型、编程范式和功能,以更好地支持SAP S/4HANA系统,并提高开发和运行ABAP应用程序的性能。 ### 回答3: ABAP是一种高级业务应用程序编程语言,用于开发SAP软件解决方案。ABAP语法包括各种关键字、数据类型、操作符、语句和类等。 首先,在ABAP语法,我们使用不同的关键字来声明变量、常量和数据类型。例如,使用“DATA”关键字来声明一个变量,使用“CONSTANTS”关键字来声明一个常量,并使用不同的数据类型(例如整数、字符、日期等)来定义变量或常量。这些关键字和数据类型使开发者能够方便地处理数据和进行计算。 其次,在ABAP语法,我们可以使用各种操作符来进行数学、逻辑和比较操作。例如,加号“+”用于加法运算,减号“-”用于减法运算,等号“=”用于比较操作等。这些操作符帮助我们在编写程序时进行各种运算和判断。 然后,在ABAP语法,我们使用各种语句来实现不同的功能。例如,我们可以使用“IF”语句来实现条件判断,根据条件的结果执行不同的操作。我们还可以使用“DO”语句来实现循环操作,重复执行一段代码。此外,还有其他语句,例如“CASE”语句、 “LOOP”语句等,用于不同的编程需求。 最后,在ABAP语法,我们还可以创建和使用类来组织和管理代码。类是一种封装了数据和方法的数据结构,可以实现面向对象的编程。通过创建类和使用类的方法,我们可以更好地管理代码,并实现可重用的功能。 综上所述,ABAP是一种用于开发SAP软件解决方案的编程语言,它有着丰富的语法规则,包括关键字、数据类型、操作符、语句和类等。了解和掌握ABAP语法对于开发高效、可靠的SAP应用程序至关重要。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值