Function实现ALV Table七:汇总,分类汇总,排序,过滤
来源:互联网 发布:追日软件 编辑:程序博客网 时间:2024/05/16 12:28
ALV标准功能汇总,分类汇总,排序,过滤这些功能除了可以直接使用它的标准功能按钮之外,你也可以在程序里设定,让ALV列表第一次显示出来就已经使用了这些功能。
用REUSE_ALV_GRID_DISPLAY实现的ALV不能在程序设定输出字段的平均值,最小值,最大值等标准功能。用OO方式实现ALV输出的就可以,请参考
http://blog.csdn.net/lhx20/archive/2008/08/26/2833234.aspx
一、排序
排序用到类型slis_t_sortinfo_alv,按条件把过滤的字段和规则设置好,添加到一个参考slis_t_sortinfo_alv类型的内表,在调用Function的时候指导内表赋给it_sort参数
二、过滤
过滤用到类型slis_t_filter_alv,按条件把排序的字段和规则设置好,添加到一个参考slis_t_filter_alv类型的内表,在调用Function的时候把内表的值赋给it_fitler参数
三、分类汇总
分类汇总是汇总和排序两个功能来进行分类和汇总的。按照排序的字段的值进行分类,对已经汇总的字段进行分类汇总。在设置排序的时候设置类型slis_t_sortinfo_alv-subtot = ‘X’ 就可以了。
四、汇总
汇总是设置要汇总的字段的Fieldcat属性,设置slis_t_fieldcat_alv-do_sum= ‘X’。
下面是源代码
TYPE-POOLS slis.
TYPES ty_tab_spfli TYPE spfliOCCURS 0.
START-OF-SELECTION.
PERFORM f_display.
*&---------------------------------------------------------------------*
*& Form f_getdata
*&---------------------------------------------------------------------*
* text
*----------------------------------------------------------------------*
* -->PT_SPFLI text
*----------------------------------------------------------------------*
FORM f_getdata TABLES pt_spfliTYPE ty_tab_spfli.
SELECT * FROM spfli INTO TABLE pt_spfli.
ENDFORM. "f_getdata
*&---------------------------------------------------------------------*
*& Form f_display
*&---------------------------------------------------------------------*
* text
*----------------------------------------------------------------------*
FORM f_display.
DATA: lt_spfli TYPE ty_tab_spfli,
lt_filter TYPE slis_t_filter_alv,
lt_sort TYPE slis_t_sortinfo_alv,
lt_fieldcat TYPE slis_t_fieldcat_alv.
PERFORM f_getdata TABLES lt_spfli.
PERFORM f_filter_build TABLES lt_filter.
PERFORM f_sort_build TABLES lt_sort.
PERFORM f_fieldcat CHANGING lt_fieldcat.
CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
EXPORTING
i_callback_program = sy-repid
it_fieldcat = lt_fieldcat
it_filter = lt_filter
it_sort = lt_sort
TABLES
t_outtab = lt_spfli.
ENDFORM. "f_display
*&---------------------------------------------------------------------*
*& Form f_fieldcat
*&---------------------------------------------------------------------*
* text
*----------------------------------------------------------------------*
* -->PT_FIELDCAT text
*----------------------------------------------------------------------*
FORM f_fieldcat CHANGINGpt_fieldcat TYPE slis_t_fieldcat_alv.
FIELD-SYMBOLS <fs_fieldcat> LIKE LINEOF pt_fieldcat.
CALL FUNCTION 'REUSE_ALV_FIELDCATALOG_MERGE'
EXPORTING
i_structure_name = 'SPFLI'
CHANGING
ct_fieldcat = pt_fieldcat
EXCEPTIONS
inconsistent_interface = 1
program_error = 2
other = 3.
LOOP AT pt_fieldcat ASSIGNING<fs_fieldcat> WHERE fieldname = 'DISTANCE'.
<fs_fieldcat>-do_sum = 'X'.
ENDLOOP.
ENDFORM. "f_fieldcat
*&---------------------------------------------------------------------*
*& Form f_filter_build
*&---------------------------------------------------------------------*
* text
*----------------------------------------------------------------------*
* -->PT_FILTER text
*----------------------------------------------------------------------*
FORM f_filter_build TABLESpt_filter TYPE slis_t_filter_alv.
DATA lwa_filter LIKE LINE OF pt_filter.
lwa_filter-fieldname = 'DISTANCE'.
lwa_filter-sign0 = 'E'.
lwa_filter-optio = 'EQ'.
lwa_filter-valut = 'MI '.
APPEND lwa_filter TO pt_filter.
ENDFORM. "f_filter_build
*&---------------------------------------------------------------------*
*& Form f_sort_build
*&---------------------------------------------------------------------*
* text
*----------------------------------------------------------------------*
* -->PT_SORT text
*----------------------------------------------------------------------*
FORM f_sort_build TABLESpt_sort TYPE slis_t_sortinfo_alv.
DATA lwa_sort LIKE LINE OF pt_sort.
lwa_sort-fieldname = 'CARRID'.
lwa_sort-up = 'X'.
lwa_sort-subtot = 'X'.
APPEND lwa_sort TO pt_sort.
ENDFORM. "f_sort_build
- Function实现ALV Table七:汇总,分类汇总,排序,过滤
- Function实现ALV Table七:汇总,分类汇总,排序,过滤
- ALV :汇总,分类汇总(小计),排序,过滤
- ALV分类汇总
- OO实现ALV TABLE 十一:ALV的聚合,排序,过滤
- OO实现ALV TABLE 十一:ALV的聚合,排序,过滤
- ALV分类汇总一例
- alv多层显示及分类汇总
- ALV TABLE 十一:ALV的聚合,排序,过滤
- Function实现ALV Table 三:功能设计
- Function实现ALV Table 四:显示样式
- Function实现ALV Table五:布局功能
- Function实现ALV Table八:事件
- Function实现ALV Table 九:编辑功能
- Function实现ALV Table八:事件
- Function实现ALV Table五:布局功能
- Function实现ALV Table 四:显示样式
- Function实现ALV Table一:最简单的ALV显示
- 新来的,占个位置
- PostgreSQL 8.3.4版本发布
- passthru驱动调试笔记
- .Net平台应用程序单一运行实例代码实现
- Windows平台上的SVN服务器架设步骤
- Function实现ALV Table七:汇总,分类汇总,排序,过滤
- linux下安装oracle10g如何实现多数据库实例运行
- Ajax demo
- 用ashx动态生成文件(转载)
- XP局域网内共享不了文件
- PHP学习路程感悟 -- 对路了真好
- 职业七年之痒变四年之痛
- XPath类-操作XML工具类
- 心血来潮