Vbscript 使用VBS Ping服务器列表

Vbscript 使用VBS Ping服务器列表,vbscript,Vbscript,我有以下脚本ping服务器列表(txt文件,每行一个服务器),如果关闭,将信息记录到csv文件中。脚本工作正常,但我无法解决脚本的两个问题: 1) 我希望脚本仅在列表中的一个服务器关闭时创建一个文件。当前,如果没有服务器关闭,它将创建一个带有标题行的空文件。我已经通过编写另一个脚本暂时修复了这个问题,该脚本稍后会删除空文件,但最好不要首先创建该文件 2) 有没有办法ping两次或三次以双重/三重检查服务器是否已关闭,然后记录它已关闭?目前,脚本记录到有时服务器关闭,而我并不认为它真的关闭了,可能

我有以下脚本ping服务器列表(txt文件,每行一个服务器),如果关闭,将信息记录到csv文件中。脚本工作正常,但我无法解决脚本的两个问题:

1) 我希望脚本仅在列表中的一个服务器关闭时创建一个文件。当前,如果没有服务器关闭,它将创建一个带有标题行的空文件。我已经通过编写另一个脚本暂时修复了这个问题,该脚本稍后会删除空文件,但最好不要首先创建该文件

2) 有没有办法ping两次或三次以双重/三重检查服务器是否已关闭,然后记录它已关闭?目前,脚本记录到有时服务器关闭,而我并不认为它真的关闭了,可能是我的互联网连接或计算机挂起了一秒钟,所以ping失败了

提前谢谢!我刚刚进入VBS,所以这对我来说是一个陌生的领域

Dim WshShell
Set WshShell = createobject("wscript.shell")
strURL = "www.yahoo.com"
set png = WshShell.exec("ping -n 1 " & strURL)
do until png.status = 1
wscript.sleep 100
loop
strPing = lcase(png.stdout.readall)
Select Case True
 Case InStr(strPing, "reply from") > 1 

dim strInputPath, strOutputPath, strStatus
dim objFSO, objTextIn, objTextOut

strSafeDate = DatePart("yyyy",Date) & Right("0" & DatePart("m",Date), 2) & Right("0" & DatePart("d",Date), 2)

strSafeTime = Right("0" & Hour(Now), 2) & Right("0" & Minute(Now), 2) & Right("0" & Second(Now), 2)

strDateTime = strSafeDate & "-" & strSafeTime

strInputPath = "C:\Users\user\Desktop\PING\serverlist.txt" '- location of input
strOutputPath = "C:\Users\user\Desktop\PING\log\" & strDateTime & ".csv" '- location of output
set objFSO = CreateObject("Scripting.FileSystemObject")
set objTextIn = objFSO.OpenTextFile( strInputPath,1 )
set objTextOut = objFSO.CreateTextFile( strOutputPath )
objTextOut.WriteLine("website,status,date")

Do until objTextIn.AtEndOfStream = True
    strComputer = objTextIn.ReadLine
        if fPingTest( strComputer ) then
             strStatus = "UP"
        else
             strStatus = "DOWN"
        end if
        if strStatus = "DOWN" then
              objTextOut.WriteLine(strComputer & "," & strStatus & "," & Now)
        end if
loop

function fPingTest( strComputer )
        dim objShell,objPing
        dim strPingOut, flag
        set objShell = CreateObject("Wscript.Shell")
        set objPing = objShell.Exec("ping " & strComputer)
    strPingOut = objPing.StdOut.ReadAll
    if instr(LCase(strPingOut), "reply") then
        flag = TRUE
        else
                flag = FALSE
        end if
        fPingTest = flag

end function

  Case Else
  End Select 

如果需要,您可以使用等待栏尝试我的修改代码:

Option Explicit
Dim strInputPath,strOutputPath,strStatus,strSafeDate,strSafeTime,strDateTime,Titre,MsgTitre,MsgAttente
Dim objFSO,objTextIn,objTextOut,ReadAllFile,Lines,Line,Ws,Command,OpenCSVFile,oExec,Temp,StartTime,DurationTime
Set Ws = CreateObject("WScript.Shell")
Titre = "Ping list of servers"
MsgTitre = Titre
MsgAttente = "Please wait ... the pinging is on progress ...."
Temp = ws.ExpandEnvironmentStrings("%Temp%")
strSafeDate = DatePart("yyyy",Date) & Right("0" & DatePart("m",Date), 2) & Right("0" & DatePart("d",Date), 2)
strSafeTime = Right("0" & Hour(Now), 2) & Right("0" & Minute(Now), 2) & Right("0" & Second(Now), 2)
strDateTime = strSafeDate & "-" & strSafeTime
strInputPath = "C:\PingServer\serverlist.txt" '- location of input
strOutputPath = "C:\PingServer\" & strDateTime & ".csv" '- location of output
set objFSO = CreateObject("Scripting.FileSystemObject")
If objFSO.FileExists(strInputPath) Then
    set objTextIn = objFSO.OpenTextFile(strInputPath,1)
else
    MsgBox "CRITICAL ERROR " & VbCrLF & "The File "& DblQuote(strInputPath) & " dosen't exists !",VbCritical,"CRITICAL ERROR " & Titre
    Wscript.Quit
End if
set objTextOut = objFSO.CreateTextFile(strOutputPath)
objTextOut.WriteLine("website;status;date")
ReadAllFile = objTextIn.ReadAll
Lines = Split(ReadAllFile,vbCrLf)
Call CreateProgressBar(MsgTitre,MsgAttente)'Create the waiting Bar
Call LancerProgressBar()'Lancement de la barre de progression
StartTime = Timer 'Debut du Compteur Timer 
For Each Line In Lines
    If OnLine(Line) = True Then
        strStatus = "UP"
        objTextOut.WriteLine(Line & ";" & strStatus & ";" & Now)
    else
        strStatus = "DOWN"
        objTextOut.WriteLine(Line & ";" & strStatus & ";" & Now)
    end if
Next
Call FermerProgressBar()'Closing the waiting Bar
DurationTime = FormatNumber(Timer - StartTime, 0) & " seconds." 'La duree de l'execution du script
Command = "cmd /c CD " & DblQuote(ExcelPath()) & " | Start Excel.exe" &" /E "& DblQuote(strOutputPath)
Ws.Popup "The pinging Script is finshed in "& DurationTime,"2",MsgTitre,64
OpenCSVFile = ws.run(Command,0,False)
'************************************************************************************************************************************************************
Function OnLine(strHost)
    Dim objPing,z,objRetStatus,PingStatus
    Set objPing = GetObject("winmgmts:{impersonationLevel=impersonate}").ExecQuery("select * from Win32_PingStatus where address = '" & strHost & "'")
    z = 0
    Do   
        z = z + 1
        For Each objRetStatus In objPing
            If IsNull(objRetStatus.StatusCode) Or objRetStatus.StatusCode <> 0 Then
                PingStatus = False
            Else
                PingStatus = True
            End If     
        Next   
        Call Pause(1)
        If z = 5 Then Exit Do 'here you can incerase or decerase the value of z = 5
    Loop until PingStatus = True
    If PingStatus = True Then
        OnLine = True
    Else
        OnLine = False
    End If
End Function
'*********************************************************************************************
Sub Pause(NSeconds)
    Wscript.Sleep(NSeconds*1000)
End Sub
'**********************************************************************************************
Function ExcelPath()
    Dim appXL,s
    Set appXL = CreateObject("Excel.Application")
    ExcelPath = appXL.Path
    appXL.Quit
    Set appXL = Nothing
End Function
'**********************************************************************************************
'Fonction pour ajouter les doubles quotes dans une variable
Function DblQuote(Str)
    DblQuote = Chr(34) & Str & Chr(34)
End Function
'**********************************************************************************************
Sub CreateProgressBar(Titre,MsgAttente)
    Dim ws,fso,f,f2,ts,ts2,Ligne,i,fread,LireTout,NbLigneTotal,Temp,PathOutPutHTML,fhta,oExec
    Set ws = CreateObject("wscript.Shell")
    Set fso = CreateObject("Scripting.FileSystemObject")
    Temp = WS.ExpandEnvironmentStrings("%Temp%")
    PathOutPutHTML = Temp & "\Barre.hta"
    Set fhta = fso.OpenTextFile(PathOutPutHTML,2,True)
    fhta.WriteLine "<HTML>"
    fhta.WriteLine "<HEAD>"
    fhta.WriteLine "<Title>  " & Titre & "</Title>"
    fhta.WriteLine "<HTA:APPLICATION"
    fhta.WriteLine "ICON = ""magnify.exe"" "
    fhta.WriteLine "BORDER=""THIN"" "
    fhta.WriteLine "INNERBORDER=""NO"" "
    fhta.WriteLine "MAXIMIZEBUTTON=""NO"" "
    fhta.WriteLine "MINIMIZEBUTTON=""NO"" "
    fhta.WriteLine "SCROLL=""NO"" "
    fhta.WriteLine "SYSMENU=""NO"" "
    fhta.WriteLine "SELECTION=""NO"" "
    fhta.WriteLine "SINGLEINSTANCE=""YES"">"
    fhta.WriteLine "</HEAD>"
    fhta.WriteLine "<BODY text=""white""><CENTER>"
    fhta.WriteLine "<marquee DIRECTION=""LEFT"" SCROLLAMOUNT=""3"" BEHAVIOR=ALTERNATE><font face=""Comic sans MS"">" & MsgAttente &"</font></marquee>"
    fhta.WriteLine "<br><img src="""" />"
    fhta.WriteLine "</CENTER></BODY></HTML>"
    fhta.WriteLine "<SCRIPT LANGUAGE=""VBScript""> "
    fhta.WriteLine "Set ws = CreateObject(""wscript.Shell"")"
    fhta.WriteLine "Temp = WS.ExpandEnvironmentStrings(""%Temp%"")"
    fhta.WriteLine "Sub window_onload()"
    fhta.WriteLine "    CenterWindow 350,100"
    fhta.WriteLine "    Self.document.bgColor = ""DarkOrange"" "
    fhta.WriteLine " End Sub"
    fhta.WriteLine " Sub CenterWindow(x,y)"
    fhta.WriteLine "    Dim iLeft,itop"
    fhta.WriteLine "    window.resizeTo x,y"
    fhta.WriteLine "    iLeft = window.screen.availWidth/2 - x/2"
    fhta.WriteLine "    itop = window.screen.availHeight/2 - y/2"
    fhta.WriteLine "    window.moveTo ileft,itop"
    fhta.WriteLine "End Sub"
    fhta.WriteLine "</script>"
    fhta.close
End Sub
'**********************************************************************************************
Sub LancerProgressBar()
    Set oExec = Ws.Exec("mshta.exe " & Temp & "\Barre.hta")
End Sub
'**********************************************************************************************
Sub FermerProgressBar()
    oExec.Terminate
End Sub
'**********************************************************************************************
选项显式
Dim strInputPath、STROUTPATH、strStatus、strSafeDate、strSafeTime、strDateTime、Titre、MsgTitre、MSGATENTE
Dim objFSO、OBJTEXTE、OBJTEXOUT、ReadAllFile、Lines、Line、Ws、Command、OpenCSVFile、oExec、Temp、StartTime、DurationTime
设置Ws=CreateObject(“WScript.Shell”)
Titre=“Ping服务器列表”
mSgTire=滴定度
MsgAttente=“请稍候…ping正在进行中…”
Temp=ws.ExpandEnvironmentStrings(“%Temp%”)
strSafeDate=DatePart(“yyyy”,Date)和Right(“0”和DatePart(“m”,Date),2)和Right(“0”和DatePart(“d”,Date),2)
strSafeTime=Right(“0”和小时(现在),2)和Right(“0”和分钟(现在),2)和Right(“0”和秒(现在),2)
strDateTime=strSafeDate&“-”和strSafeTime
strInputPath=“C:\PingServer\serverlist.txt”—输入的位置
strOutputPath=“C:\PingServer\”&strDateTime&“.csv”—输出的位置
设置objFSO=CreateObject(“Scripting.FileSystemObject”)
如果存在objFSO.files(strInputPath),则
设置objtude=objFSO.OpenTextFile(strInputPath,1)
其他的
MsgBox“严重错误”&VbCrLF&“文件”&DblQuote(strInputPath)&dosen't exists!”,VbCritical,“严重错误”&Titre
Wscript.Quit
如果结束
设置objTextOut=objFSO.CreateTextFile(strOutputPath)
objtexout.WriteLine(“网站;状态;日期”)
ReadAllFile=objteme.ReadAll
行=拆分(ReadAllFile,vbCrLf)
调用CreateProgressBar(MsgTitre,MsgAttente)'创建等待栏
调用LancerProgressBar()'Lancement de la barre de progression
StartTime=计时器的首个计时器
每行中的每一行
如果在线(Line)=True,则
strStatus=“向上”
写入线(行&“;”&strStatus&“;”&Now)
其他的
strStatus=“向下”
写入线(行&“;”&strStatus&“;”&Now)
如果结束
下一个
调用FermerProgressBar()'关闭等待栏
DurationTime=FormatNumber(计时器-开始时间,0)和“秒”。“在脚本执行期间”
Command=“cmd/c CD”&DblQuote(ExcelPath())&“| Start Excel.exe”&”/E“&DblQuote(strOutputPath)
Ws.Popup“ping脚本在中找到”&DurationTime,“2”,MsgTitre,64
OpenCSVFile=ws.run(命令,0,False)
'************************************************************************************************************************************************************
在线功能(strHost)
尺寸对象,z,对象状态,PingStatus
Set objPing=GetObject(“winmgmts:{impersonationLevel=impersonate}”).ExecQuery(“从Win32中选择*,其中地址=””&strHost&“”)
z=0
做
z=z+1
对于objRetStatus中的每个objRetStatus
如果IsNull(objRetStatus.StatusCode)或objRetStatus.StatusCode为0,则
PingStatus=False
其他的
PingStatus=True
如果结束
下一个
呼叫暂停(1)
如果z=5,则退出“执行”,您可以在此处增加或减少z=5的值
循环直到PingStatus=True
如果PingStatus=True,则
在线=真
其他的
在线=错误
如果结束
端函数
'*********************************************************************************************
子暂停(N秒)
Wscript.Sleep(秒*1000)
端接头
'**********************************************************************************************
函数ExcelPath()
Dim appXL,s
设置appXL=CreateObject(“Excel.Application”)
ExcelPath=appXL.Path
appXL.退出
设置appXL=Nothing
端函数
'**********************************************************************************************
'Fonction pour ajour les double引用了一个变量
函数DblQuote(Str)
DblQuote=Chr(34)和Str&Chr(34)
端函数
'**********************************************************************************************
分包商(滴度、MSGATENTE)
尺寸ws、fso、f、f2、ts、ts2、Ligne、i、fread、LireTout、NbLigneTotal、Temp、病理输出HTML、fhta、oExec
设置ws=CreateObject(“wscript.Shell”)
设置fso=CreateObject(“Scripting.FileSystemObject”)
Temp=WS.ExpandEnvironmentStrings(“%Temp%”)
PathOutPutHTML=Temp&“\Barre.hta”
设置fhta=fso.OpenTextFile(PathOutPutHTML,2,True)
fhta.WriteLine“”
fhta.WriteLine“”
fhta.WriteLine“&标题和”
fhta.WriteLine“”
fhta.WriteLine“”
fhta.WriteLine“”
fhta.WriteLine“&MsgAttente&”
fhta.WriteLine“
” fhta.WriteLine“” fhta.WriteLine“” fhta.WriteLine“Set ws=CreateObject(““wscript.Shell”)” fhta.WriteLine“Temp=WS.ExpandEnvironmentStrings(“%Temp%”)” fhta.WriteLine“子窗口加载() fhta.WriteLine“中心窗口350100” fhta.WriteLine“Self.document.bgColor=”“DarkOrange”“” fhta.WriteLine“末端接头” fhta.WriteLine“子中心窗口(x,y)” fhta.WriteLine“Dim iLeft,itop” fhta.WriteLine“window.resizeTo x,y” fhta.WriteLine“iLeft=window.screen.availWidth/2-x/2” fhta.WriteLine“itop