摘要:在维护企业网络的时候,我们需要根据IP地址来确定IP地址所属地区和区域,如果需要实现这种需求,依靠记忆是不可能实现的。我看周边很多同事大多数依赖excel表格的搜索功能来实现,但是一次性打开很多的表,不但占用很多电脑资源,效率也不高。为了提高效率,我们可以用p
在维护企业网络的时候,我们需要根据IP地址来确定IP地址所属地区和区域,如果需要实现这种需求,依靠记忆是不可能实现的。我看周边很多同事大多数依赖excel表格的搜索功能来实现,但是一次性打开很多的表,不但占用很多电脑资源,效率也不高。为了提高效率,我们可以用python的办法来制作一个IP地址查询器。
一、操作前准备
1.1、在操作前,我们需要下载一个pycharm的IDE工具,我用的版本如下图所示:
1.2 本次实验我们需要用到的模块是ipaddress和pandas;大家需要在电脑上安装这两个模块。操作办法是:
在导航栏中输入pandas;ipaddress模块是内置模块,不需要安装了。
二、操作步骤
2.1 安装完成以上模块后,就可以通过import调用pandas了。以下是完整的代码:其中
INPUT_IP.txt文本是用来将我们需要确认的IP地址存放的文本;NFZX_2_IP.xls是存放网段信息的excel文件。excel文件设置如下图所示,第一列为IP地址网段;第二列为IP网段的使用属性。
import ipaddressimport pandas as pddef read_ip_addresses(File_path):"""读取 IP 地址文件"""try:with open(file_path, 'r', encoding='utf-8') as file:return [line.strip for line in file.readlines]except FileNotFoundError:print(f"文件 {file_path} 不存在")return except Exception as e:print(f"读取文件 {file_path} 时发生错误: {e}")return def read_excel_file(file_path):"""读取 Excel 文件中的网段和对应内容"""try:xls_file = pd.ExcelFile(file_path)df = xls_file.parse('Sheet1')return df.iloc[:, 0], df.iloc[:, 1]except FileNotFoundError:print(f"文件 {file_path} 不存在")return , except Exception as e:print(f"读取文件 {file_path} 时发生错误: {e}")return , def check_ip_in_network(ip, network):"""检查 IP 地址是否属于网段"""try:ip_obj = ipaddress.ip_address(ip)network_obj = ipaddress.ip_network(network)return ip_obj in network_objexcept ValueError as e:print(f"IP 地址或网段格式错误: {e}")return Falsedef main:# 文件路径ip_file_path = 'INPUT_IP.txt'excel_file_path = 'NFZX_2_IP.xls'# 读取 IP 地址和 Excel 文件ip_addresses = read_ip_addresses(ip_file_path)network_column, content_column = read_excel_file(excel_file_path)# 检查每个 IP 是否属于任何网段,并返回对应内容results = for ip in ip_addresses:for network, content in zip(network_column, content_column):if check_ip_in_network(ip, network):results.append(f"{ip}: {content}")break # 一旦找到匹配的网段,就可以停止检查# 输出结果for result in results:print(result)if __name__ == "__main__":main来源:网络专家vlog
免责声明:本站系转载,并不代表本网赞同其观点和对其真实性负责。如涉及作品内容、版权和其它问题,请在30日内与本站联系,我们将在第一时间删除内容!