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

本文介绍了一个使用 ABAP 编写的程序,该程序能够自动刷新显示用户信息的 ALV 列表。列表每隔5秒自动更新一次,通过调用 FM 'REUSE_ALV_LIST_DISPLAY' 实现。程序包括读取数据、显示数据和定时刷新等功能。

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` 语句捕获连接失败或数据读取错误。 - 设置合理的刷新间隔时间,避免频繁访问导致系统负载过高。 #### 相关问题
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值