【OO ALV实现合并行和列】

文章讨论了如何在ABAP编程中使用ABAPALV库实现表格的转置功能,特别是处理多行表头的合并和单元格合并的问题,以及作者分享的代码片段及其遇到的问题和调整过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

需求场景

做了一个FUNCTION ALV,按行展示,但是用户需要做一个转置,前面列按行显示,后面数量列由按列显示调整为按行显示。查了一下,好像是FUNCTION ALV实现不了,参考了一位博主实现了这个需求。
ABAP ALV多行表头(合并列,合并单元格)

问题点

这里面实现按行显示的代码有问题,我这里做了一些调整,代码如下:

FORM set_merge_vert USING col row len value.
  CLEAR: wa_col_merge,it_col_merge.
  wa_col_merge-col_id    = row.
  wa_col_merge-outputlen = len.
  APPEND wa_col_merge TO it_col_merge.

  CALL METHOD g_alv_grid->z_set_merge_vert
    EXPORTING
      col           = col
      value         = value
    CHANGING
      tab_col_merge = it_col_merge.

  "设置Style
  CLEAR:wa_style-style.
  wa_style-style     = alv_style_font_bold_no
  + alv_style_align_center_center
  + alv_style_color_key.

  CALL METHOD g_alv_grid->z_set_cell_style
    EXPORTING
      row   = row
      col   = col
      style = wa_style-style.
ENDFORM.                    " SET_MERGE_VERT

  METHOD z_set_merge_vert.
    FIELD-SYMBOLS <fs_cols> TYPE lvc_s_co01.
    FIELD-SYMBOLS <fs_data> TYPE lvc_s_data.
    DATA outputlen TYPE i.

    SORT tab_col_merge.

    LOOP AT tab_col_merge ASSIGNING <fs_cols>.
      IF <fs_cols>-col_id    LE 0.                CONTINUE. ENDIF.
      IF <fs_cols>-outputlen LE <fs_cols>-col_id. CONTINUE. ENDIF.
      outputlen = <fs_cols>-outputlen - <fs_cols>-col_id.
      LOOP AT mt_data ASSIGNING <fs_data>
      WHERE col_pos = col  AND
      ( row_pos BETWEEN <fs_cols>-col_id AND
      <fs_cols>-outputlen ).

        IF <fs_data>-row_pos = <fs_cols>-col_id.
          <fs_data>-mergevert = outputlen.
          <fs_data>-value = value.
        ELSE.
          CLEAR <fs_data>-mergevert.
          CLEAR <fs_data>-value.
        ENDIF.
      ENDLOOP.
    ENDLOOP.
  ENDMETHOD.                    "Z_SET_MERGE_VERT

效果如下

在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值