VBA中Ping主机是否连接的2种方法
时 间:2017-11-30 20:09:26
作 者:在水一方 ID:20576 城市:沈阳
摘 要:调用方法
MsgBox Pings("192.168.0.1")
或
MsgBox sPing("192.168.0.1")
正 文:
第一个函数:返回TRUE / FALSE
Public Function Pings(strMachines As String) As Boolean
Dim aMachines() As StringDim machine As Variant
Dim objPing As Object
Dim objStatus As Object
aMachines = Split(strMachines, ";")
For Each machine In aMachines
Set objPing = GetObject("winmgmts:{impersonationLevel=impersonate}").ExecQuery("select * from Win32_PingStatus where address = '" & machine & "'")
For Each objStatus In objPing
If IsNull(objStatus.StatusCode) or objStatus.StatusCode <> 0 Then
Debug.Print ("machine " & machine & " is not reachable")
Pings = False
Else
Pings = True
End If
Next
Next
End Function
第二个函数:返回网络通畅度
Function sPing(sHost As String) As String
Dim oPing As Object, oretStatus As Object
Set oPing = GetObject("winmgmts:{impersonationLevel=impersonate}").ExecQuery _
("select * from Win32_PingStatus where address = '" & sHost & "'")
For Each oretStatus In oPing
If IsNull(oRetStatus.StatusCode) or oretStatus.StatusCode <> 0 Then
sPing = "Status code is " & oretStatus.StatusCode
Else
sPing = "Pinging " & sHost & " with " & oretStatus.BufferSize & " bytes of data:" & Chr(10)
sPing = sPing & "Time (ms) = " & vbTab & oretStatus.ResponseTime & Chr(10)
sPing = sPing & "TTL (s) = " & vbTab & oretStatus.ResponseTimeToLive
End If
Next
End Function
Access软件网官方交流QQ群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- 统计当月之前(不含当月)的记录...(03.11)
- 【Access Inputbo...(03.03)
- 按回车键后光标移动到下一条记录...(02.12)
- 【Access Dsum示例】...(02.07)
- Access对子窗体的数据进行...(02.05)
- 【Access高效办公】上月累...(01.09)
- 【Access高效办公】上月累...(01.06)
- 【Access Inputbo...(12.23)
- 【Access Dsum示例】...(12.16)

学习心得
最新文章
- 仓库管理实战课程(8)-商品信息功...(04.01)
- 仓库管理实战课程(7)-链接表(03.31)
- 仓库管理实战课程(6)-创建查询(03.29)
- 仓库管理实战课程(5)-字段属性(03.27)
- 设备装配出入库管理系统;基于Acc...(03.24)
- 仓库管理实战课程(4)-建表操作(03.22)
- 仓库管理实战课程(3)-需求设计说...(03.19)
- 仓库管理实战课程(2)-软件背景和...(03.18)
- 仓库管理实战课程(1)-讲师介绍(03.16)
- 统计当月之前(不含当月)的记录数怎...(03.11)