ip_excel_html =,excel--转化IP地址为十进制

将IP地址转换成十进制

=LEFT(a1,FIND(".",a1)-1)*256^3+mid(a1,FIND(".",a1)+1,FIND(".",a1,FIND(".",a1)+1)-FIND(".",a1)-1)*256^2+mid(a1,FIND(".",a1,FIND(".",a1)+1)+1,FIND(".",a1,FIND(".",a1,FIND(".",a1)+1)+1)-FIND(".",a1,FIND(".",a1)+1)-1)*256+right(a1,len(a1)-FIND(".",a1,FIND(".",a1,FIND(".",a1)+1)+1))

excel 合并列 =OFFSET(A$1,INT((ROW(A1)-1)/2),MOD(ROW(A1)-1,2))

MYSQL中IP和进制相互转化(

用mysql内置函数转换ip地址和数字

利用两个内置函数

inet_aton:将ip地址转换成数字型

inet_ntoa:将数字型转换成ip地址

PHP

echo ip2long('192.168.1.38');

输出:3232235814

MYSQL

SELECT INET_ATON('192.168.1.38');

输出:3232235814

两个函数返回的结果是一样的,都是A*256*256*256+B*256*256+C*256+D的算法

192*256*256*256+168*256*256+1*256+38 = 3 232 235 814

反过来,从int转换为IP地址分别是php的long2ip()和mysql的INET_NTOA()。

def decimal_to_ip(decimal_ip): ip_parts = [] for i in range(4): ip_parts.append(str(decimal_ip % 256)) decimal_ip //= 256 ip_parts.reverse() ip_address = ".".join(ip_parts) return ip_address 在ip_conversion()函数中添加以下代码 将十进制IP换为标准IP地址格式 ip_address = decimal_to_ip(decimal_ip) 在窗口中显示换结果 result_label.config(text="标准IP地址: " + ip_address)和 import tkinter as tk def ip_conversion(): ip = entry.get() if ip.isdigit(): # 判断IP地址格式 ip1 = int(ip) if ip1 > 4294967296: # 2**32,判断ip地址是否合法 result_label.config(text="IP地址不合法") else: decimal_ip = ip2decimalism(ip) result_label.config(text="十进制IP地址: " + decimal_ip) else: ip_list = ip.split(".") ipgeshi = len(ip_list) # 统计列表中元素个数 if ipgeshi > 3 and ipgeshi < 5: # 判断ip地址是否合法 for v in ip_list: v1 = int(v) if v1 > 254: # 判断ip地址是否合法 result_label.config(text="IP地址不合法") break else: for i in range(len(ip_list)): ele = bin(int(ip_list[i])) # 二进制 ip_list[i] = ele[2:] # 把0b切掉 得到后面的二进制01内容 if len(ip_list[i]) < 8: # 补全到八位 strl = "0" * (8 - len(ip_list[i])) + ip_list[i] ip_list[i] = strl val = "".join(ip_list) # 列表中的所有元素按照空白字符拼接成一个字符串 decimal_ip = int("0b" + val, base=2) result_label.config(text="十进制IP地址: " + str(decimal_ip)) break else: result_label.config(text="IP地址不合法") def ip2decimalism(ip): # 32位二进制 dec_value = 0 v_list = ip.split('.') # 将ip分装到列表中 v_list.reverse() # 将列表元素反向排列 t = 1 for v in v_list: dec_value += int(v) * t # 计算32位二进制 t = t * (2 ** 8) # 返回十进制结果 return str(dec_value) 创建窗口 window = tk.Tk() window.title("IP地址换") window.geometry("300x200") 创建输入框和按钮 entry = tk.Entry(window) entry.pack(pady=10) convert_button = tk.Button(window, text="换", command=ip_conversion) convert_button.pack() 创建结果标签 result_label = tk.Label(window, text="") result_label.pack(pady=10) 运行窗口主循环 window.mainloop()结合
最新发布
07-16
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值