我的公司里有人制作了一个VBScript (.vbs)脚本。它打开和关闭某些应用程序,这个应用程序有一个托盘图标,每次它关闭(通过控制台杀死)应用程序时,托盘图标仍然存在。因此,在运行脚本一到两天后,任务栏上会保留数百万个应用程序的图标。
windows的VBScript中是否有刷新任务栏并清除这些图标的说明?
下面是scrpit:
*****************************************************************************************
' Progam Name: CheckConnection.vbs
' Program Purpose: This script check for an internec connection, the program pings to some domains,
' wait some seconds (5 seconds) before the next try, if a domain is found, reset all counters,
' and wait secondsBeforeNextCheck seconds before next check
' If the programs raise nMaxRetriesBeforeStartProgram then kill the program that
' manage the connection and start it again.
' Usage: This Script must be placed in ONE OF THE FOLLOWING PATHS
' 1) Start --> All Programs --> Start Up
' 2) HKLM\Software\Microsoft\Windows\CurrentVersion\Run
' 3)HKCU\Software\Microsoft\Windows\CurrentVersion\Run
' 4) Or you can create a task through:
' Start --> All Programs --> Accessories-->System Tools --> Scheduled Tasks--> Add Scheduled Task
' --> Follow the Wizard'
' 5) The program VZAccess Manager.exe must be configured to autoconnect through
' Tools --> Preferences --> WWan --> Connect Options --> Automatically Connect (this must be checked)
' 6) Also to autorefresh the ip the vzaccess manager.exe must be configured with an script when c onnect.
' Author: Benito Lopez
' Date: 06152009
' Revision 1.1 : (11272009) -f was added to force the program VZAccess manager.exe to terminate.
' *****************************************************************************************
Dim WshShell
Set WshShell = WScript.CreateObject("WScript.Shell")
Dim objfso, objfile
Set objfso = CreateObject("Scripting.FileSystemObject")
Dim secondsBeforeNextCheck
Dim strDomains(6)
Dim nMaxRetriesBeforeStartProgram
Dim nCounterRetries
Const ForReading=1, ForWriting=2, ForAppending=8
strDomains (0) = "www.google.com"
strDomains (1) = "www.yahoo.com"
strDomains (2) = "www.chilpak.com"
strDomains (3) = "www.microsoft.com"
strDomains (4) = "www.flutec.com"
strDomains (5) = "www.flutec.com.mx"
strLogFilename = "c:\checkconnectionlog.log"
filepinger = "c:\pingresult.log"
nMaxRetriesBeforeStartProgram =5
secondsBeforeNextCheck = 60000
secondsBeforeNextTry = 15000
secondsBeforeAppStart = 2000
secondsAfterAppStart = 60000
Call Main()
Sub Main()
set objfile = objfso.OpenTextFile(strLogFilename, 8,True)
WHILE 1
nCounterRetries = 0
FOR i = 0 TO 5 STEP 1
'Check the connection status if zero, means
'There is no internet connection or the domain is down
If not IsThereInternetConnection(strDomains(i)) THEN
'Let suppose the domain is down, so we must try with the next domain
nCounterRetries = nCounterRetries + 1
IF nCounterRetries >= nMaxRetriesBeforeStartProgram THEN
'Close the program
targetprogram = "taskkill /im " & chr(34) & "VZAccess Manager.exe" & chr(34) & " /f"
WshShell.Exec(targetprogram)
'Wait Applications Events 2 seconds
Wscript.Sleep(secondsBeforeAppStart)
'Start the program
targetprogram = chr(34) & "C:\Program Files\Verizon Wireless\VZAccess Manager\VZAccess Manager.exe" & chr(34) & " -m"
WshShell.Exec(targetprogram)
'Wait for the applications loads completely 1 seconds
WScript.Sleep(secondsAfterAppStart)
'Reset the counters
nCounterRetries = 0
Wscript.Sleep secondsBeforeNextCheck
END IF
'But we must wait some seconds before the next try
Wscript.Sleep secondsBeforeNextTry
ELSE
'If we get a reply from the current domain,
'Everything is OK, The only we need to do is Wait until the next time to check
'Reset Counter
nCounterRetries = 0
WScript.Sleep secondsBeforeNextCheck
END IF
NEXT
Wend
End Sub
FUNCTION IsThereInternetConnection(strDomain)
on error resume next
'Create some cons values
'Make the ping
Dim strRun
strRun = "%comspec% /c ping -n 1 " & strDomain & " > " & filepinger
Dim objwss
Set objwss = CreateObject("WScript.Shell")
'Hide the windows and wait the app to terminate
WriteLog "Pinging " & strDomain & " ..."
objwss.Run strRun,0,True
Set objwss = Nothing
''Read the ping
Dim strotf
Dim fso
Dim otf
strotf=""
set fso = CreateObject("Scripting.FileSystemObject")
set otf = fso.OpenTextFile(filepinger,ForReading)
strotf = otf.ReadAll
fso.DeleteFile filepinger
set fso = nothing
set otf = nothing
'Test the ping
IF InStr(strotf,"Reply from")>0 THEN
IsThereInternetConnection = TRUE
ELSE
IsThereInternetConnection = FALSE
END IF
WriteLog "Pinging Result " & IsThereInternetConnection & " Done."
End FUNCTION
Sub WriteLog(strLog)
on error resume next
Set objfile = objfso.GetFolder(strLogFilename)
if objfile.size > 50000 then
objfso.Close
objfso.DeleteFile strLogFilename
set objfile = objfso.OpenTextFile(strLogFilename, 8,True)
end if
'Add some useful information
strData = Now() & " - "
objfile.WriteLine strData & strLog
End Sub发布于 2010-01-28 04:15:30
将鼠标指针移到孤立图标上后,系统托盘中的孤立图标将消失。我猜这可以通过向系统托盘窗口发送WM_MOUSEMOVE消息以编程方式完成,但是VBScript没有访问Windows API的权限。
我建议您使用一些外部实用程序来刷新系统托盘,并从您的脚本运行它。例如,CodeProject上有一个TrayIconBuster实用程序,它可以每5秒清理一次托盘。(但它需要.NET框架。)或者你可以自己写一个类似的工具。
若要从VBScript代码运行应用程序,可以使用WshShell.Run或WshShell.Exec方法。您可以在您的脚本中找到示例。
发布于 2010-09-28 21:27:33
使用vb调用内部带有重新启动资源管理器命令的bat文件或reg文件
Windows注册表编辑器版本5.00 -HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\TrayNotify
发布于 2015-04-30 10:11:56
程序告诉explorer戴上或脱下图标。如果你与图标交互,资源管理器试图告诉程序做任何事情,并注意到它不在那里,并删除图标。
Taskkill可以做两件事。它可以要求一个程序关闭(该程序可以提出一个对话框“保存文件?-是/否/取消”),该程序关闭的设计或用于/f它终止程序没有通知程序,所以该程序不能要求资源管理器删除图标。
尝试不带/f开关的Taskkill。您总是可以在没有的情况下调用它两次,然后使用/f开关调用它。
https://stackoverflow.com/questions/2142214
复制相似问题