ALV List是SAP中的一种报表方式,一般的ALV报表有一个表头,再加上表内容。对报表的设置有排序,分类汇总和合计等预设置。
ALV报表显示方式有2种,一种是Grid方式,一种是List方式,分别调用不同的Function来实现。下面是主要代码及说明。

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中的列对应的字段名称也必须使用大写字母,否则数据不会显示出来。

转载于:https://www.cnblogs.com/zhumk/archive/2005/05/26/162672.html

ABAP:ALV List报表相关推荐

  1. 给 ABAP ALV 报表的数据行增添颜色效果试读版

    零基础 ABAP 学习教程系列文章的目录 ABAP 标准培训教程 BC400 学习笔记之一:ABAP 服务器的架构和一个典型的 ABAP 程序结构介绍 ABAP 标准培训教程 BC400 学习笔记之二 ...

  2. 48 行代码给 ABAP ALV 报表的数据行增添颜色效果

    按照前一步骤 27 行代码开发一个最简单的 SAP ALV 报表完成之后,我们仅使用 27 行代码,就得到了如下图所示的 ABAP ALV 输出: 本步骤我们在此基础上,为这个朴素的 ALV 报表,增 ...

  3. 如何在 SAP ABAP ALV 报表里以交通灯的方式显示某一列的值

    在本教程的这篇步骤里,我们介绍了 ALV 层次顺序表的输出实现明细. SAP ABAP ALV 层次顺序表如何使用双表头(Multiple Headers)进行数据输出 本文介绍如何在 ALV 层次顺 ...

  4. 77 行代码实现 ABAP ALV 中的双击事件处理试读版

    零基础 ABAP 学习教程系列文章的目录 ABAP 标准培训教程 BC400 学习笔记之一:ABAP 服务器的架构和一个典型的 ABAP 程序结构介绍 ABAP 标准培训教程 BC400 学习笔记之二 ...

  5. 77 行代码实现 ABAP ALV 中的双击事件处理

    我们在 ALV 开发专题的第二步骤里,为 ALV 输出的数据行,增添了颜色显示的功能: ALV 开发专题 27 行代码开发一个最简单的 SAP ALV 报表 给 ABAP ALV 报表的数据行增添颜色 ...

  6. 动手开发一个有用的 ABAP ALV 工具 - 查看指定用户的 ABAP 传输请求试读版

    本专栏计划的文章数在 150 篇左右,到 2022年10月6日为止,目前已经更新了 56 篇,专栏完成度为 37.3% 零基础 ABAP 学习教程系列文章的目录 1. ABAP 标准培训教程 BC40 ...

  7. abap alv新增行数据_ABAP_ALV_最好教程 最全知识整理.doc

    ABAP_ALV_最好教程 最全知识整理 ABAP ALV 知识整理 亿力科技 ABAP开发组 目 录 一.ALV简介3 1.简介3 2.ALV_GRID介绍3 3.其它描述3 二.开发ALV的基本流 ...

  8. ABAP ALV 总结

    ABAP ALV 总结整理 目录 一.ALV简介 1.简介 2.ALV_GRID介绍 3.其它描述 二.开发ALV的基本流程 三.ALV相关开发细节 1.标准ALV与对象ALV的共同开发细节 2.标准 ...

  9. ABAP ALV 总结整理

     ABAP ALV 总结整理 目录 一.ALV简介 1.简介 2.ALV_GRID介绍 3.其它描述 二.开发ALV的基本流程 三.ALV相关开发细节 1.标准ALV与对象ALV的共同开发细节 2 ...

最新文章

  1. 如何在系统崩溃时从C++中获取函数调用栈信息?
  2. 学计算机高考英语听力考试时间,北京高考英语听力考试时间
  3. [读书笔记]C#中get与set的用法
  4. 计算机硬盘有usb借口吗,为什么移动硬盘不建议插在台式机前置USB接口上
  5. 安装虚拟环境virtualenv 适用于centos系统 2020
  6. [Eclipse插件] Eclipse设置Tab键为空格(ctrl+shirt+f格式化生效)!
  7. 【BZOJ2131】免费的馅饼,坐标转换与DP
  8. 用PhotoSwipe制作相册,手势可放大
  9. 你知道怎么离线安装全局 node 模块吗?
  10. emWin 2天速成实例教程013_修改BUTTON按钮等控件背景皮肤颜色_SetBkColor
  11. html创建qq注册页面,用javascript制作qq注册动态页面
  12. 单片机控制可控硅调压
  13. MySQL创建表和约束条件(四)
  14. ce变速注入dll失败_调用CE变速DLL注入的软件含HOOK模块
  15. 学习记录之星瞳检测交通标志1
  16. 带宽与网速之间的换算
  17. UnityShader(四)基础光照
  18. 简单粗暴理解支持向量机(SVM)及其MATLAB实例
  19. Linux的系统操作界面
  20. R语言在线地图神器:Leaflet for R包(二)基础底图

热门文章

  1. python代码案例详解-新手必学Python爬虫之Scrapy框架案例详解
  2. python之父-Python之父宣布退休,但Python仍在吞噬世界
  3. python 贴吧自动回复机-python_库学习_02_微信自动回复机器人
  4. python画饼图-python matplotlib画饼图
  5. 我在学python-我在大学毕业后学习Linux、python的一些经验
  6. python为什么中文要encoding-python中encoding是什么意思
  7. python代码壁纸-python设置windows桌面壁纸的实现代码
  8. python对象编程例子-python面向对象编程:python类和实例讲解
  9. python100行代码-python代码统计 100行
  10. python菜鸟教程n-Python 元组