SAPGUI_PROGRESS_INDICATOR 显示处理进度条

原文链接:https://blog.csdn.net/hjackyua/article/details/62885137
————————————————
版权声明:本文为CSDN博主「熙來攘往」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。


在运行报表的时候,经常会遇到数据量很大,每一次查询都会花费很长的时间,郁闷的是你不知道到底查询的进度,
所以可以利用函数“SAPGUI_PROGRESS_INDICATOR”来计算进度,显示给用户看。

使用这个函数,你只要输入查询次数和提示文本即可,下面用一个例子来看看这函数的用法:

DATA: g_total TYPE i,
g_cnt type i,
g_index type i.

DATA: gt_sflight TYPE TABLE OF sflight WITH HEADER LINE.

START-OF-SELECTION.

  SELECT * INTO CORRESPONDING FIELDS OF TABLE gt_sflight
  FROM
  sflight.

  DESCRIBE TABLE gt_sflight LINES g_total.


    LOOP AT gt_sflight.
      g_cnt = g_cnt + 1.
      PERFORM progress_indicator USING g_cnt g_total 'Progressing'.
    ENDLOOP.

    WRITE 'success'.

*---------------------------------------------------------------------*
*       FORM progress_indicator                                       *
*---------------------------------------------------------------------*
*       ........                                                      *
*---------------------------------------------------------------------*
*  -->  VALUE(P_CUR)                                                  *
*  -->  VALUE(P_TOTAL)                                                *
*  -->  VALUE(P_TEXT)                                                 *
*---------------------------------------------------------------------*
FORM progress_indicator USING value(p_cur)
                        value(p_total)
                        value(p_text).
  DATA:lv_text(50) TYPE c,
       lv_idx(3) TYPE n.

  lv_idx = ( P_CUR / P_TOTAL ) * 100.

  CONCATENATE lv_idx '%:' p_text INTO lv_text.

  CALL FUNCTION 'SAPGUI_PROGRESS_INDICATOR'
       EXPORTING
            percentage = lv_idx
            text       = lv_text
       EXCEPTIONS
            OTHERS     = 0.

ENDFORM.

效果:

 

本人常年接收SAP运维和远程项目,ECC,S/4HANA,CRM,WDA. 远程人天可谈,终身售后,有活请联系V信:18925782767(问问题免费,欢迎交流!) !!请关注本人技术分享公众号:SAP翔子(可扫头像二维码) 每天分享新知识,博客文章也会陆续整理并迁移至公众号,与您一起共同学习
原文地址:https://www.cnblogs.com/rainysblog/p/14930701.html