使用python來獲取整個局域網內可以連通的主機ip地址:
整體是思路就是
1、先獲取我本機的ip地址
2、拿到我本機ip後,截取ip的最後一段,保留前一部分網段信息
3、調用cmd命令,循環從1循環255次到255來ping 整個網段內可以ping通的ip
通過Ping TTL 大於0 判斷是否可ping通
4、最後得到可以ping通的ip地址
# -*- coding: utf-8 -*-
import platform
import os
import time
import threading
import socket
live_ip = 0
def get_os():
os = platform.system()
if os == "Windows":
return "n"
else:
return "c"
def ping_ip(ip_str):
cmd = ["ping", "-{op}".format(op=get_os()),
"1", ip_str]
output = os.popen(" ".join(cmd)).readlines()
for line in output:
if str(line).upper().find("TTL") >= 0:
print("ip: %s 在線" % ip_str)
global live_ip
live_ip += 1
break
def find_ip(ip_prefix):
'''''
給出當前的ip地址段 ,然後掃描整個段所有地址
'''
threads = []
for i in range(1, 256):
ip = '%s.%s' % (ip_prefix, i)
threads.append(threading.Thread(target=ping_ip, args={ip, }))
for i in threads:
i.start()
for i in threads:
i.join()
def find_local_ip():
"""
獲取本機當前ip地址
:return: 返回本機ip地址
"""
myname = socket.getfqdn(socket.gethostname())
myaddr = socket.gethostbyname(myname)
return myaddr
if __name__ == "__main__":
print("開始掃描時間: %s" % time.ctime())
addr = find_local_ip()
args = "".join(addr)
ip_pre = '.'.join(args.split('.')[:-1])
find_ip(ip_pre)
print("掃描結束時間 %s" % time.ctime())
print('本次掃描共檢測到本網絡存在%s臺設備' % live_ip)
運行結果:
開始掃描時間: Sun Apr 26 00:10:28 2020
ip: 192.168.1.11 在線
ip: 192.168.1.6 在線
ip: 192.168.1.2 在線
ip: 192.168.1.3 在線
ip: 192.168.1.1 在線
ip: 192.168.1.4 在線
ip: 192.168.1.100 在線
ip: 192.168.1.255 在線
掃描結束時間 Sun Apr 26 00:10:32 2020
本次掃描共檢測到本網絡存在8臺設備
到此,我們就獲取到了整個局域網中的全部可連接網絡。