在SAP中设计自动刷新的报表代码 (又一例)

本文介绍了一个使用 ABAP 编写的程序,该程序能够自动刷新显示用户信息的 ALV 列表,并每五秒自动更新一次数据。通过调用 FM 'THUSRINFO' 获取用户信息并利用 'RFC_PING_AND_WAIT' 函数进行后台任务刷新。

REPORT z_alv_auto_refresh.
*>*********************************************************************
* This report displays User's info (SM04) using the FM :              *
* REUSE_ALV_LIST_DISPLAY                                              *
* The list is auto-refreshed (refresh time : 5 seconds)               *
*---------------------------------------------------------------------*

TYPE-POOLS: slis.                      " ALV Global Types

DATA :
  gt_user LIKE uinfo OCCURS 0 WITH HEADER LINE. " User info in SM04

*---------------------------------------------------------------------*
START-OF-SELECTION.

  PERFORM f_read_data.

  PERFORM f_display_data.

*---------------------------------------------------------------------*
*       Form  F_LIRE_DATA
*---------------------------------------------------------------------*
FORM f_read_data.

  REFRESH gt_user.

* Get User's info
  CALL FUNCTION 'THUSRINFO'
       TABLES
            usr_tabl = gt_user.

* Wait in a task
  PERFORM f_call_rfc_wait.

ENDFORM.                               " F_READ_DATA
*---------------------------------------------------------------------*
*      Form  F_DISPLAY_DATA
*---------------------------------------------------------------------*
FORM f_display_data.

  DEFINE m_sort.
    add 1 to ls_sort-spos.
    ls_sort-fieldname = &1.
    append ls_sort to lt_sort.
  END-OF-DEFINITION.

  DEFINE m_event_exit.
    clear ls_event_exit.
    ls_event_exit-ucomm = &1.
    ls_event_exit-after = 'X'.
    append ls_event_exit to lt_event_exit.
  END-OF-DEFINITION.

  DATA :
    ls_layout     TYPE slis_layout_alv,
    lt_sort       TYPE slis_t_sortinfo_alv,
    ls_sort       TYPE slis_sortinfo_alv,
    lt_event_exit TYPE slis_t_event_exit,
    ls_event_exit TYPE slis_event_exit.

* Build Sort Table
  m_sort 'ZEIT'.

* Build Event Exit Table
  m_event_exit '&NTE'.                 " Refresh

  ls_layout-zebra = 'X'.
  ls_layout-colwidth_optimize = 'X'.

  CALL FUNCTION 'REUSE_ALV_LIST_DISPLAY'
       EXPORTING
            i_callback_program      = sy-cprog
            i_callback_user_command = 'USER_COMMAND'
            is_layout               = ls_layout
            i_structure_name        = 'UINFO'
            it_sort                 = lt_sort
            it_event_exit           = lt_event_exit
       TABLES
            t_outtab                = gt_user.

ENDFORM.                               " F_DISPLAY_DATA
*---------------------------------------------------------------------*
*       FORM USER_COMMAND                                             *
*---------------------------------------------------------------------*
FORM user_command USING i_ucomm     TYPE syucomm
                        is_selfield TYPE slis_selfield.     "#EC CALLED

  CASE i_ucomm.
    WHEN '&NTE'.
      PERFORM f_read_data.
      is_selfield-refresh = 'X'.
      SET USER-COMMAND '&OPT'.         " Optimize columns width
  ENDCASE.

ENDFORM.                               " USER_COMMAND
*---------------------------------------------------------------------*
*      Form  F_CALL_RFC_WAIT
*---------------------------------------------------------------------*
FORM f_call_rfc_wait.

  DATA lv_mssg(80).                                         "#EC NEEDED

* Wait in a task
  CALL FUNCTION 'RFC_PING_AND_WAIT' STARTING NEW TASK '001'
    PERFORMING f_task_end ON END OF TASK
    EXPORTING
      seconds               = 5        " Refresh time
      busy_waiting          = space
    EXCEPTIONS
      RESOURCE_FAILURE      = 1
      communication_failure = 2  MESSAGE lv_mssg
      system_failure        = 3  MESSAGE lv_mssg
      OTHERS                = 4.

ENDFORM.                               " F_CALL_RFC_WAIT
*---------------------------------------------------------------------*
*      Form  F_TASK_END
*---------------------------------------------------------------------*
FORM f_task_end USING u_taskname.

  DATA lv_mssg(80).                                         "#EC NEEDED

* Receiving task results
  RECEIVE RESULTS FROM FUNCTION 'RFC_PING_AND_WAIT'
    EXCEPTIONS
      RESOURCE_FAILURE      = 1
      communication_failure = 2  MESSAGE lv_mssg
      system_failure        = 3  MESSAGE lv_mssg
      OTHERS                = 4.

  CHECK sy-subrc EQ 0.
  SET USER-COMMAND '&NTE'.             " Refresh

ENDFORM.                               " F_TASK_END
*************** END OF PROGRAM Z_ALV_AUTO_REFRESH ********************* 

相关连接:http://blog.youkuaiyun.com/CompassButton/archive/2006/09/09/1198709.aspx
来源:http://www.sap-basis-abap.com/abap/auto-refresh-alv-list.htm

### 实现 Excel 中 SAP 数据的自动刷新功能 在 Excel 中实现 SAP 数据的自动刷新功能,可以通过 **SAP GUI Scripting** 和 **VBA 宏** 技术相结合的方式完成。该方法允许 Excel 通过调用 SAP 的 GUI 接口定期获取最新数据,并更新到工作表中,实现自动化数据刷新。 #### 使用 SAP GUI Scripting 实现自动刷新 SAP 提供了 GUI Scripting API,允许通过外部程序(如 Excel VBA)模拟用户操作,从而实现对 SAP 系统的自动化访问。通过编写 VBA 脚本,可以定时执行 SAP 事务码或函数模块,获取最新数据并刷新 Excel 中的表格内容。 以下是一个实现自动刷新的 VBA 示例代码: ```vba Sub AutoRefreshSAPData() Dim SapGuiAuto As Object Dim SAPApp As Object Dim SAPCon As Object Dim session As Object On Error Resume Next Set SapGuiAuto = GetObject("SAPGUI") Set SAPApp = SapGuiAuto.GetScriptingEngine Set SAPCon = SAPApp.Children(0) Set session = SAPCon.Children(0) On Error GoTo 0 If Not IsObject(session) Then MsgBox "无法连接到 SAP 会话,请确保 SAP打开并在主界面。" Exit Sub End If ' 执行事务码,例如查看用户列表 session.StartTransaction "SM04" ' 假设在事务中执行某些操作后提取数据 ' 例如获取用户列表(示例为静态数据) Dim userList(1 To 3, 1 To 4) As String userList(1, 1) = "100" userList(1, 2) = "USER01" userList(1, 3) = "CLIENT01" userList(1, 4) = "192.168.1.1" ' 将数据写入 Excel Sheets("Sheet1").Range("A1:D3").ClearContents Sheets("Sheet1").Range("A1").Resize(3, 4) = userList End Sub ``` 为了实现定时刷新,可以在 Excel 中设置一个定时器,通过 `Application.OnTime` 方法周期性调用上述刷新子程序: ```vba Sub ScheduleRefresh() Application.OnTime Now + TimeValue("00:01:00"), "AutoRefreshSAPData" End Sub ``` 将 `ScheduleRefresh` 作为启动宏,在 Excel 打开时自动运行,即可实现每分钟自动刷新一次 SAP 数据的功能。 #### 使用 SAP 提供的“从 Excel 更新 SAP”工具 SAP 系统中提供了“从 Excel 更新 SAP”工具栏按钮,允许用户直接在 SAP 系统中选择 Excel 文件并进行数据更新。虽然该功能主要用于数据上传,但也可以结合 Excel 的数据导入功能实现 SAP 数据的自动刷新。具体操作如下: 1.SAP 的“轻松访问”界面中,点击“从 Excel 更新 SAP”按钮。 2. 选择包含 SAP 数据的 Excel 文件。 3. 系统将根据文件内容执行数据更新操作,适用于需要周期性更新特定字段的场景[^1]。 #### 自动化录制与模板生成 SAP GUI 支持前台操作的录制功能,用户可以录制一次 SAP 操作流程,系统会自动生成 Excel 模板。该模板可用于未来在任何 SAP 环境中重复执行相同操作,简化了自动刷新脚本的开发流程。该功能适用于简单操作的快速录制,复杂操作仍需通过开发 BDC 实现[^2]。 #### 数据同步与异常处理 在实现自动刷新过程中,必须考虑异常处理机制。例如: - 确保 SAP GUI Scripting 已启用。 - 检查 SAP 系统是否已登录并在主界面。 - 使用 VBA 的 `On Error` 语句捕获连接失败或数据读取错误。 - 设置合理的刷新间隔时间,避免频繁访问导致系统负载过高。 #### 相关问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值