`

ABAP:ALV List报表

阅读更多
[color=darkblue]ALV List是SAP中的一种报表方式,一般的ALV报表有一个表头,再加上表内容。对报表的设置有排序,分类汇总和合计等预设置。
ALV报表显示方式有2种,一种是Grid方式,一种是List方式,分别调用不同的Function来实现。下面是主要代码及说明。
[/color]
TYPE-POOLS: slis.

form frm_show_data .
  DATA: l_line TYPE slis_listheader.
  DATA: hinfo TYPE slis_t_listheader.
  DATA: fieldcat TYPE slis_t_fieldcat_alv WITH HEADER LINE.
  DATA: layout TYPE slis_layout_alv .
  data: sortable type SLIS_T_SORTINFO_ALV with header line.

  clear fieldcat.
  add 1 to fieldcat-col_pos.
  fieldcat-fieldname = 'LGORT'. " 对应的内表中的字段名称
  fieldcat-seltext_m =  '库存地点'. "ALV中显示的标题
  fieldcat-outputlen = 15. " 列的显示宽度,可以不设置
  append fieldcat.

*   按照上面的方式添加所有需要在ALV中显示的字段

  clear fieldcat.
  add 1 to fieldcat-col_pos.
  fieldcat-fieldname = 'CSPEM'.
  fieldcat-seltext_m =  '待报废数量'.
  fieldcat-do_sum = 'X'.  "汇总,该字段在ALV的最底部汇总
  append fieldcat.

*-------Field List Table Setting--------

*---------------Begin of SortTable info
*--排序字段为分类字段,如果ALV需要自动分类合计,那么合计字段必须设置为排序字段,多个字段按照下面方式逐个添加
*clear sortable.
*sortable-FIELDNAME = 'LGORT'.
*sortable-UP = 'X'.
*sortable-DOWN = SPACE.
*sortable-SUBTOT = 'X'.
*append sortable.
*-----------------End of SortTable Info

layout-colwidth_optimize = 'X'. "列宽度自动根据内容优化

    CALL Function '()FUNCTION 'REUSE_ALV_GRID_DISPLAY'
    EXPORTING
      i_interface_check        = ''
      i_callback_program       = sy-repid
      is_layout                = layout
*      i_callback_pf_status_set = 'SET_PF_STATUS' "如果ALV使用自定义的工具栏,如果使用系统工具栏则忽略该行
*      i_callback_user_command  = 'USER_COMMAND' "自定义工具栏的事件
      it_fieldcat              = fieldcat[]
* 这里是动态嵌入的代码,用于ALV控制头部和尾部数据
      I_CALLBACK_HTML_TOP_OF_PAGE       = 'ALV_TOP_OF_PAGE' "如果需要表头
*    it_sort = sortable[] "如果有排序和分类汇总,需要该行
* 动态代码结束
    TABLES
      t_outtab                 = GI_OUTPUT "ALV数据输出使用的内表
    EXCEPTIONS
      program_error            = 1
      OTHERS                   = 2.

endform.                    " frm_show_data


*------用于设置ALV的GUI状态
FORM set_pf_status USING rt_extab TYPE slis_t_extab.
*  SET PF-STATUS '0100'.
ENDFORM.                    "SET_PF_STATUS

FORM user_command  USING r_ucomm LIKE sy-ucomm
                                   rs_selfield TYPE slis_selfield.
  CASE r_ucomm.
    WHEN 'Z_EXPORT'.
      PERFORM frm_excel_out.
  ENDCASE.
ENDFORM.                    "user_command


*-------ALV Commit Setting of ALV_top_of_page--------
FORM alv_top_of_page USING cl_dd TYPE REF TO cl_dd_document.
  DATA: m_p TYPE i.
  DATA: m_buff TYPE string.
*表头其实完全可以是一个html文件,自己使用html语言进行格式控制
  m_buff = '<html>'.
  CALL METHOD cl_dd->html_insert
    EXPORTING
      contents = m_buff
    CHANGING
      position = m_p.

m_buff = '<center><H2>配件报废品种汇总表</H2></Center>'.
CALL METHOD CL_DD->HTML_INSERT
EXPORTING
  CONTENTS = m_buff
CHANGING
  POSITION = m_p.

CONCATENATE '报表日期:' S_DATE-LOW ' TO ' S_DATE-HIGH  '<BR>' into m_buff.
CALL METHOD CL_DD->HTML_INSERT
EXPORTING
  CONTENTS = m_buff
CHANGING
  POSITION = m_p.


  m_buff = '</html>'.
  CALL METHOD cl_dd->html_insert
    EXPORTING
      contents = m_buff
    CHANGING
      position = m_p.
ENDFORM.                    "ALV_top_of_page

注: 在ALV中,需要注意所有添加的需要显示的列,都必须在相应的内表中有对应的字段,否则,只要使用合计或者分类汇总都会导致程序的崩溃。

注意:在SAP ABAP程序中,字符串的大小写很重要,在单引号包围的字符串中,一般来说都应该用大写,特别是在调用一些系统的方法时传入字符串参数时,例如在ALV中,Call Function 'REUSE_ALV_GRID_DISPLAY'时,传入的下面的两个参数:
i_callback_pf_status_set = 'SET_PF_STATUS'
i_callback_user_command  = 'USER_COMMAND'
就必须使用大写字符串,否则就会出现Perform_not_found的系统错误。
另外,传入到ALV中的列对应的字段名称也必须使用大写字母,否则数据不会显示出来。
分享到:
评论

相关推荐

    ABAP-ALV进阶

    ALV 全称为 ABAP List Viewer,在 R/3 4.6C 之前,已经正式更名为 SAP List Viewer。ALV 提供给系统用户多种丰富的交互功能,包括报表输出、列表显示、交互功能等。 二、ALV的用户界面 ALV 的用户界面分为三个部分...

    SAP ABAP ALV分页显示

    本篇文章将深入分析一个基于SAP ABAP的ALV(Application List Viewer)分页显示的实现方法。ALV是SAP GUI中用于展示表格数据的一种灵活方式,它提供了丰富的自定义功能,例如排序、筛选、分组等,能够满足各种复杂的...

    [ABAP]Function实现ALV Table 二:ALV的弹出窗口形式

    在ABAP(Advanced Business Application Programming)中,ALV(ABAP List Viewer)是SAP提供的一种用于显示数据表的标准化接口。本篇我们将深入探讨如何使用Function来实现ALV Table的弹出窗口形式,这对于创建用户...

    ABAP OOALV学习文档

    **ABAP OOALV**(Object-Oriented Application List Viewer)是一种用于SAP系统的高级列表显示技术,主要用于生成复杂的报表和列表视图。自R/3 4.6C版本起,其名称由“ABAP ListViewer”更改为“SAP ListViewer”。...

    【SAP ABAP开发】 ALV报表开发教程

    在SAP ABAP开发中,ALV(Application List Viewer)是一种用于展示数据列表的强大工具,它提供了丰富的功能来满足各种业务需求,例如排序、筛选、分组等。本教程旨在详细介绍如何在ABAP环境中使用ALV开发高质量的...

    ALV报表 abap报表

    ALV(Application List Viewer)是一种常用的ABAP报表工具,通过它可以快速生成报表,具有良好的可读性和交互性。本文将通过一个实际的ALV报表示例,详细介绍ALV报表的编写过程和相关技术要点。 一、报表标题和描述...

    ABAP ALV 报表基础模板(两种)

    在 SAP 的 ABAP 开发环境中,ALV(Application List Viewer)是一种常用的技术来展示数据列表。本篇文档将详细介绍一种用于创建 ABAP ALV 报表的基础模板,并通过具体的代码示例来解释如何构建和使用这种模板。 ###...

    ABAP开发ALV中自定义按钮实现

    在ABAP开发中,ALV(Accelerated List Viewer)是一种常用的数据展示工具,它提供了灵活的表格布局和交互性。用户通常需要对ALV进行定制,以满足特定的需求,例如添加自定义按钮来实现数据的打印或导出到Excel。本篇...

    ABAP OOALV

    **ABAP OOALV**(Object-Oriented Application List Viewer)是一种基于SAP GUI的列表展示技术,它采用面向对象的方式实现数据的展示。OOALV相比传统的ALV(Application List Viewer)提供了更强大的功能和更灵活的...

    abap 自定义alv的一个小例子

    在ABAP中,ALV(Advanced List Viewer)是一种强大的报表工具,通过自定义ALV,可以满足不同的业务需求。本篇文章将提供一个自定义ALV的小例子,用于帮助读者快速入门和理解ABAP中的ALV报表。 报表的基本结构 在...

    ABAP OO去掉ALV中的标准工具栏

    在SAP ABAP中,ALV广泛应用于报表展示和数据浏览场景。 #### 2. 面向对象编程 (OO) 面向对象编程是一种编程范式,它使用“对象”来设计软件。在ABAP中,面向对象的特性使得开发者可以更灵活地处理复杂的应用逻辑,...

    SAP ABAP开发学习——第10课:OOALV(视频教程)

    在本课程中,我们将深入探讨SAP ABAP的面向对象技术在ALV(ABAP List Viewer)中的应用,这是SAP ABAP开发学习的第10课,专注于OOALV。这个主题对于任何想要在SAP系统中进行高效数据展现和处理的开发者来说都是至关...

    abap alv 总结

    ABAP ALV 是 SAP 系统中的一种报表方式,提供了标准化、简单化的表单格式和用户接口。ABAP ALV 能够提供给用户一个统一的表单格式和用户接口,提高报表输出的可读性和功能性。 一、ALV 简介 ABAP ALV 是 SAP 系统...

    SAP_ABAP_ALV技术

    总结来说,SAP ABAP ALV技术是SAP系统中不可或缺的一部分,它简化了大数据量报表的开发,提高了用户体验。无论是初学者还是经验丰富的开发者,都应该掌握这项技能,以便在SAP环境中有效地处理和展示数据。

    ABAP_ALV_知识整理

    ALV(SAP List Viewer)是一种在SAP系统中广泛使用的报表展示方式,也被称为ABAP表单浏览器。它的主要功能是提供一个标准化且简单的表格展示方式,使R/3系统中的表格更具统一性与易用性。ALV支持诸如汇总、排序、...

    SAP ABAP ALV 详解

    ALV 列表是 SAP 系统中的新的列表标准,可以在 ABAP 程序或者 SAP Query 等报表中输出,除了传统列表输出时可以显示数据和少量的交互功能(退出,下翻页等)之外,还提供了大量的其他交互功能,包括排序,汇总等。...

    ABAP--ALV总结

    ABAP(Advanced Business Application Programming)是一种高级商业应用编程语言,ALV(Application List View)是 SAP 系统中的一种报表显示工具。本文将介绍如何使用 ABAP 语言开发 ALV 报表,并对 ALV 的主要功能...

    ABAP ALV入门教程

    ABAP ALV是SAP系统中用于输出数据的高级列表查看器(Advanced List Viewer)的简称,它作为ABAP程序中的一个控件,用于实现更加丰富和用户友好的数据展示功能。ABAP ALV入门教程旨在为初学者提供一个易于理解和实践...

    SAP-ABAP-ALV

    SAP ABAP ALV(SAP List Viewer)是一种灵活的工具,用于在SAP开发环境中显示和操作列表。ALV报表提供基础的列表操作,并可通过自定义扩展以适应各种复杂的应用场景。尽管ALV Grid在某些开发项目中也可用于数据的...

    abap ALV 开发

    SAP提供了修饰报表的功能模块ALV (ABAP LIST VIEWER)。这个模块是用来增强输出报表的可读性和功能性。 ALV 开发基准

Global site tag (gtag.js) - Google Analytics