首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Excel调用Shell命令时奇怪的状态栏行为

使用Excel调用Shell命令时奇怪的状态栏行为
EN

Stack Overflow用户
提问于 2013-12-31 08:23:31
回答 1查看 257关注 0票数 1

我使用以下子程序调用shell命令,作为使用excel中的VBA的更大进程的一部分:

代码语言:javascript
复制
Sub runShellScript(ByVal directory As String, command As String)
Dim terminal
Dim output

DoEvents
Application.StatusBar = "Processing data with python...this can take a while"

Set terminal = CreateObject("WScript.Shell")
terminal.Currentdirectory = directory
output = terminal.Run(command, 0, True)

Set output = Nothing
Set terminal = Nothing
End Sub

一切都很好,除了我无法让状态栏按我所希望的方式运行。目前,它正确启动(也就是说,状态栏更改为“使用python.处理数据”),但几秒钟后该消息被清除,状态栏恢复到默认的“就绪”状态。更奇怪的是,如果我在任何行停止该函数,它会返回到“用python处理数据.”

显然,这与终端独立于excel实例这一事实有关,但考虑到我的代码正在等待shell脚本完成,我不明白为什么状态栏会被“释放”。

任何修正,或指向正确方向的指针都将不胜感激。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-12-31 13:46:43

试着跟踪微软的例子。它们还操作DisplayStatusBar值:

代码语言:javascript
复制
oldStatusBar = Application.DisplayStatusBar 
Application.DisplayStatusBar = True 
Application.StatusBar = "Please be patient..." 
Workbooks.Open filename:="LARGE.XLS" 
Application.StatusBar = False 
Application.DisplayStatusBar = oldStatusBar
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20854211

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档