python局域网alive ip侦听
python局域网alive ip侦听
作者:vpoet
mails:vpoet_sir@163.com
注:写着玩,欢迎copy
# -*- coding: cp936 -*-
# coding = utf-8 import os
import re
import thread
import time
import socket
import sys def Ping_Ip(Curr_Ip): global Count_Thread,lock,ThreadsNum #print "*****************Chile_Thread-Begin****************"+"\n" ping_cmd = "ping" +" "+Curr_Ip Ping_Answer = os.popen(ping_cmd).readlines()
patt = r'TTL=([0-9]{2})'
TTL_Str=re.findall(patt,Ping_Answer[2]) if len(TTL_Str) == 0:
#print Curr_Ip+"is Not Alive"
pass
#print "*****************Chile_Thread-Over****************"+"\n"
else:
HostInfo = socket.gethostbyaddr(Curr_Ip)
Mac_address=Get_Mac_Addr(Curr_Ip)
#print "Mac_address"+Mac_address
print "\n"+"Alive Host-----> "+"HostComputerName:"+HostInfo[0]+" Mac_address:"+Mac_address+"\t"+"Ip:"+Curr_Ip #print "*****************Chile_Thread-Over****************"+"\n" lock.acquire()
Count_Thread = Count_Thread+1
if Count_Thread ==ThreadsNum:
print "*****************NetWork_End***************"
lock.release() def Get_Mac_Addr(Curr_Ip): Mac_cmd = "nbtstat -A "+Curr_Ip
Mac_Info = os.popen(Mac_cmd).readlines() Mac_Info_Sum="" for index in range(0,len(Mac_Info)):
Mac_Info_Sum=Mac_Info_Sum+Mac_Info[index] patt_mac = r'= (.{2}-.{2}-.{2}-.{2}-.{2}-.{2})'
mac_addr= re.findall(patt_mac,Mac_Info_Sum)
return mac_addr[0] def GetAliveIp(Net_iP_Init,IpBegin,IpEnd):
SplitIp = Net_iP_Init.split(".")
Ip1=SplitIp[0]
Ip2=SplitIp[1]
Ip3=SplitIp[2] Prefix_Ip = Ip1+"."+Ip2+"."+Ip3+"." for Ip_Last in range(IpBegin,IpEnd+1):
Curr_Ip=Prefix_Ip+str(Ip_Last) thread.start_new_thread(Ping_Ip, (Curr_Ip,))
time.sleep(2) def GetNetGate():
Netgate_cmd = "ipconfig /all"
Netgate_info = os.popen(Netgate_cmd).readlines() Netgate_info_Str = ""
for index in range(0,len(Netgate_info)):
Netgate_info_Str=Netgate_info_Str+Netgate_info[index]
#print Netgate_info_Str
#print type(Netgate_info_Str) patt_hn = r'主机名 . . . . . . . . . . . . . : (.+)'
Host_Name_Local = re.findall(patt_hn,Netgate_info_Str) Rent_Ip_Begin=r'获得租约的时间 . . . . . . . . . : (.+)'
Rent_Ip_Begins=re.findall(Rent_Ip_Begin,Netgate_info_Str) Rent_Ip_End=r'租约过期的时间 . . . . . . . . . : (.+)'
Rent_Ip_Ends=re.findall(Rent_Ip_End,Netgate_info_Str) patt_ipv6 = r'本地链接 IPv6 地址. . . . . . . . : ([a-z0-9]{3,4}::[a-z0-9]{3,4}:[a-z0-9]{3,4}:[a-z0-9]{3,4}:[a-z0-9]{3,4}%[0-9]{2})'
ipv6 = re.findall(patt_ipv6,Netgate_info_Str) patt_ipv4 = r'IPv4 地址 . . . . . . . . . . . . : ([0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3})'
ipv4 = re.findall(patt_ipv4,Netgate_info_Str) YanMas= r'子网掩码 . . . . . . . . . . . . : ([0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3})'
YM = re.findall(YanMas,Netgate_info_Str) Netgates = r'默认网关. . . . . . . . . . . . . : ([0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3})'
Ng = re.findall(Netgates,Netgate_info_Str) Patt_dhcp = r'DHCP 已启用 . . . . . . . . . . . : (.{1,2})'
dhcp_Is=re.findall(Patt_dhcp,Netgate_info_Str) Patt_dhcp_server = r'DHCP 服务器 . . . . . . . . . . . : ([0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3})'
dhcp_server = re.findall(Patt_dhcp_server,Netgate_info_Str) print "本地主机名: "+Host_Name_Local[0]
print "本机IPv6地址: "+ipv6[0]
print "本机IPv4地址: "+ipv4[0]
print "子网掩码: "+YM[0]
print "默认网关: "+Ng[0]
print "是否启用DHCP: "+dhcp_Is[0]
print "DHCP服务器IP: "+dhcp_server[0]
print "动态租约起始时间: "+Rent_Ip_Begins[0]
print "动态租约过期时间: "+Rent_Ip_Ends[0] return Ng[0] if __name__ == "__main__": Count_Thread = 0
lock = thread.allocate_lock()
print "*****************NetWork_Begin**************" Net_iP_Init=GetNetGate() IpBegin = raw_input("请输入侦听起始IP:")
IpEnd = raw_input("请输入侦听结束IP:") IntIpBegin = int(IpBegin)
IntIpEnd = int(IpEnd) ThreadsNum = IntIpEnd+1-IntIpBegin GetAliveIp(Net_iP_Init,IntIpBegin,IntIpEnd)
运行截图:
python局域网alive ip侦听的更多相关文章
- SQL Server使用侦听器IP访问时遇到"The target principal name is incorrect. Cannot generate SSPI context"
在测试SQL Server 2016 Always On时,在创建侦听器后,在客户端使用SSMS, 可以用侦听器名称访问Always On集群,但是使用侦听器IP访问时遇到"The targ ...
- WCF:没有终结点在侦听可以接受消息的*这通常是由于不正确的地址或者 SOAP操作导致的。
没有终结点在侦听可以接受消息的 http://xx.com/WebService.svc. 这通常是由于不正确的地址或者 SOAP 操作导致的.如果存在此情况,请参见 InnerException 以 ...
- GSM短信侦听的便宜方案
侦听GSM短信常用的是OsmocomBB + C118方案,主要是用luca/gsmmap分支.使用ccch_scan这个程序可以把通信封装成GSMTAP发给本机,然后用WireShark接收GSMT ...
- Socket基础之-启动异步服务侦听
Socket网络编程第一篇: 本文主要是以代码为主. .NET技术交流群 199281001 .欢迎加入 1 //负责监听的套接字 private Socket socketServer; //通知一 ...
- 如何将数据库引擎配置为侦听多个 TCP 端口
SQL Server 2005 为 SQL Server 启用 TCP/IP 后,数据库引擎将侦听连接点上是否有传入的连接(由 IP 地址和 TCP 端口号组成).下列步骤将创建一个表 ...
- [vue]计算和侦听属性(computed&watch)
先看一下计算属性 vue只有data区的数据才具备响应式的功能. 计算和侦听属性 - v-text里可以写一些逻辑 <div id="example"> {{ mess ...
- Mysql不改默认侦听回环地址而ssh通道连接的办法
Mysql不改默认侦听回环地址而ssh通道连接的办法 文:铁乐与猫 比较新版的mysql默认侦听的网卡地址是本地回环地址:127.0.0.1: 比如你在/etc/mysql/my.cnf配置文件中往往 ...
- 异形Modbus客户端 和 异形modbus服务器之间的通讯 侦听模式的modbus-tcp客户端通讯
前言 本文将使用一个Github公开的组件技术来实现一个异形ModBus TCP的客户端,方便的对异形Modbus tcp的服务器进行读写,这个服务器可以是电脑端C#设计的,也可以是特殊设备实现的,也 ...
- 用VLC读取摄像头产生RTSP流,DSS侦听并转发(二)
用VLC读取摄像头产生RTSP流,DSS侦听并转发(二) 之前介绍过<用VLC读取摄像头产生RTSP流,DSS主动取流转发(一)>本文介绍另一种方法. 摄像机地址是192.1.101.51 ...
随机推荐
- 理解 Linux 配置文件分类和使用
理解 Linux 配置文件分类和使用 本文说明了 Linux 系统的配置文件,在多用户.多任务环境中,配置文件控制用户权限.系统应用程序.守护进程.服务和其它管理任务.这些任务包括管理用户帐号.分配磁 ...
- Inorder Successor in BST 解答
Question Given a binary search tree and a node in it, find the in-order successor of that node in th ...
- qt画刷和画笔
# -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' #画刷和画笔:QBrush 定义了 QPainter 的填充模式,具 ...
- Handsontable 新增一行 默认值
效果图:
- LeetCode——Symmetric Tree
Given a binary tree, check whether it is a mirror of itself (ie, symmetric around its center). For e ...
- 飘逸的python - 解决一个有限制的组合需求
假设有一个团队技能的需求. 这类技能是要集齐所有指定的人就能激活. 但是因为同一个人又2种身份存在,比如杨戬/神杨戬,于是便产生了组合. 这种组合跟普通组合不一样,普通组合可以随意组合.而这种组合是每 ...
- 线程:CountDownLatch同步工具
一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待. 类似计数器,当计数器的值为0时,继续往下执行. package ch03; import java.util.R ...
- 经典SQL语句大全(转载)
原文http://www.cnblogs.com/yubinfeng/archive/2010/11/02/1867386.html#top 一.基础 1.说明:创建数据库CREATE DATABAS ...
- C#多线程之Parallel中 类似于for的continue,break的方法
好久没写东西了,终于找到点知识记录下... 利用ParallelLoopState对象来控制Parallel.For函数的执行,ParallelLoopState对象是由运行时在后台创建的: Para ...
- ubuntu 快捷图标
ubuntu的图标都存在 /usr/share/applications下 图标是Desktop的后缀 首先gedit /usr/share/applications/xx.Desktop xx为应用 ...