时间:2021-05-22
本文的批处理可以让您知道自己所在局域网的同一网段下都有哪些IP被使用了。不得不承认,我在创造这个批处理的时候想法很奇怪,甚至有些愚蠢。
:::::::查看所有子网IP.bat:::::::@echo offtitle 查看所有子网IPset /a Online=0set /a Offline=0set /a Total=256set ExportFile=子网IP在线统计.txt:: 初始化在线IP与不在线IP的个数为零,共扫描256个IP,结果输出的文件名set StartTime=%time%:: 记录程序的开始时间for /f "delims=: tokens=2" %%i in ('ipconfig /all ^| find /i "IP Address"') do set IP=%%i:: 获得本机IP [注1]if "%IP%"=="" echo 未连接到网络 & pause & goto :EOFif "%IP%"==" 0.0.0.0" echo 未连接到网络 & pause & goto :EOF:: 当IP为空或 0.0.0.0 时,提示未连接并退出该程序for /f "delims=. tokens=1,2,3,4" %%i in ("%IP%") do ( set /a IP1=%%i set /a IP2=%%j set /a IP3=%%k set /a IP4=%%l):: 以句点为分隔符,分别将IP的四个十进制数赋给四个变量set /a IP4=0echo 在线的IP:>%ExportFile%:: 初始化IP的第四个数值为零,并创建结果输出文件:RETRYping %IP1%.%IP2%.%IP3%.%IP4% -n 1 -w 200 -l 16>nul && set /a Online+=1 && echo %IP1%.%IP2%.%IP3%.%IP4%>>%ExportFile% || set /a Offline+=1:: ping 目标IP [注2]set /p =[将本文底部评论4中的退格符替换到此处]set /a Scanned=%Online%+%Offline%set /a Progress=(%Online%+%Offline%)*100/%Total%set /p =正在扫描:%Scanned%/%Total% 扫描进度:%Progress%%%:: 删除当前行的内容,并重新显示进度信息 [注3]set /a IP4+=1 if %IP4% lss %Total% goto :RETRY:: 当IP的第四个数值小于总数时,跳转回 :RETRY 处,重复执行直到全部 ping 完为止echo.echo.set EndTime=%time%:: 记录程序的结束时间set /a Seconds = %EndTime:~6,2% - %StartTime:~6,2%set /a Minutes = %EndTime:~3,2% - %StartTime:~3,2%if %Seconds% lss 0 set /a Seconds += 60 & set /a Minutes -= 1if %Minutes% lss 0 set /a Minutes += 60:: 计算时间差set /a Percent=%Online%*100/(%Online%+%Offline%):: 计算在线百分比echo 在线IP个数: %Online%echo 不在线IP个数: %Offline%echo 在线百分比: %Percent%%%echo 统计耗时: %Minutes%分%Seconds%秒echo 统计日期: %date% %time:~0,-3%echo.>>%ExportFile%echo 在线IP个数: %Online%>>%ExportFile%echo 不在线IP个数: %Offline%>>%ExportFile%echo 在线百分比: %Percent%%%>>%ExportFile%echo 统计耗时: %Minutes%分%Seconds%秒>>%ExportFile%echo 统计日期: %date% %time:~0,-3%>>%ExportFile%echo 记录已保存到文件"%ExportFile%"中::显示结果并将结果保存到文件中pause::::::::::::::::::::::::::::::::注1. ipconfig 是内置于 Windows 的 TCP/IP 应用程序,用于显示本地计算机网络适配器的物理地址和IP地址等配制信息,这些信息一般用来检验手动配置的 TCP/IP 设置是否正确。当在网络中使用 DHCP 服务时, ipconfig 可以检测到计算机中分配到了什么IP地址,是否配置正确,并且可以释放,重新获取IP地址。这些信息对于网络测试和故障排除都有重要的作用。[3]
更详细的说明请参阅 ipconfig/? 。ipconfig /all ,参数 /all 表示查看详细的网络配置。命令 ipconfig /all ^| find /i "IP Address" 表示在 'ipconfig /all 的结果中,以 "IP Address" 为查找对象,进行搜索(其结果类似于:IP Address. . . . . . . . . . . . : 10.30.11.51 )。
而整条命令中的 for 语句,则表示在上述结果中,以冒号为间隔(delims=:),查找第2个字串(tokens=2)。很明显,所找到的结果就是自己电脑当前的IP地址了(如果您只有一快网卡或是只启用了一个网卡的话。显然,对于多个网卡会显示出多个IP的情况,我并没有考虑的太全面)。[关于 for 更详细请参阅 4.2.4 小节]
另外,注意到在 ipconfig /all ^| find /i "IP Address" 中有一个转义字符 ^ ,它的作用是让后面的管道命令 | 生效,而不是让程序把 | 误解为 for 语句里参数的一部分。
注2. ping 其实才是本批处理的核心部分。命令 ping 的主要作用是通过发送数据包并接收应答信息来检测两台计算机之间的网络是否连通。比如我可以输入 ping 10.30.11.35 以便查看我是否能与我所在的局域网中IP为 10.30.11.35 的机器连通。如果我不懂批处理的话,也许我就得从 IP 10.30.11.1 开始,挨个地 ping 到 IP 10.30.11.255 ,才能达到我在本小节的最初目的。
在批处理中 ping 的3个参数 -n 1 -w 200 -l 16 分别表示:仅 ping 一遍[-n 1],等待200毫秒后按超时考虑[-w 200],发送16字节的数据[-l 16]。
另外,此命令行中同时用到了两个 && 和一个 || 的组合命令,我不得不承认这种复杂的逻辑关系会给您带来阅读上的困难。
注3. 这里使用了 set /p =显示内容
本文的使用程度并不大,却很有趣,至少并没有想象中的那么愚蠢。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1)基本思路:要判断两个IP地址是否在同一个网段,将它们的IP地址分别与子网掩码做与运算,得到的结果为网络号,如果网络号相同,就在同一子网,否则,不在同一子网。
子网掩码是用来判断任意两台计算机的IP地址是否属于同一子网络的根据。最为简单的理解就是两台计算机各自的IP地址与子网掩码进行AND运算后,如果得出的结果是相同的
对于如何判断IP地址是否在同一网段,首先得知道子网掩码的概念,详细过程如下:1、子网掩码是一个32位地址,子网掩码的作用是用于屏蔽IP地址的一部分以区别网络标识
在没有路由器的情况下,在同一个IP子网内的主机才能通信。主机不在同一网段内,即使通过交换机或集线器连接了也无法相互通信。不信您可以试一下,用两台不同网段IP的主
子网掩码又叫网络掩码,地址掩码,子网络遮罩,它是一种用来指明一个IP地址的哪些位标识的是主机所在的子网,以及哪些位标识的是主机的位掩码。 子网掩码和IP地址的