python IP地址转整数
作者:蒋乐兴 发布时间:2023-06-08 22:38:25
标签:python,ip,地址
背景
今天有人问我 “为什么数据库中有人推荐使用 int 类型来保存 IP 地址?”。现在(2020年)来看这个东西已经有点过时了,一方面是磁盘空间不在那么贵,另一方面是 IPv6 与这条法则不兼容。
下面我们就来看一下把 IPv4 地址转换成整数的原理和收益各是什么。
转换的原理
一个 IPv4 类的地址共分为四个部分 0.0.0.0 然而每一个部分的取值范围都在 0 ~ 255;也就是说每一个部分都可以用一个字节来保存,总共写个字节就够了,4 个字节不就是 int 吗?
第一步 把 IP 地址的各个部分转换为一个字节,并拼接它们,那么会得到一个 4 字节的串。
import struct
def aton(ip_address: str) -> bytes:
result = []
for i in ip_address.split('.'):
result.append(struct.pack("!B", int(i)))
return b''.join(result)
第二步 把字节串转换成整数。
In [2]: aton("127.0.0.1")
Out[2]: b'\x7f\x00\x00\x01'
In [3]: int.from_bytes(b'\x7f\x00\x00\x01','big')
Out[3]: 2130706433
这样我们就把 IPv4 地址转换成了一个整数,完整的代码如下。
import struct
def aton(ip_address: str) -> bytes:
result = []
for i in ip_address.split('.'):
result.append(struct.pack("!B", int(i)))
return b''.join(result)
if __name__ == "__main__":
bts = aton("127.0.0.1")
print(int.from_bytes(bts, 'big'))
运行效果如下。
python3 main.py
2130706433
转换的收益与限制
如果不做转换可以使用 varchar 来保存 IPv4 地址,这样的话需要 15 (3*4 + 3) 个字节才行;如果转换一下只需要 4 个字节就行了,节约了磁盘空间,可能会多用点 cpu 时间。
今天来说 IPv6 已经是主流,它的长度直接从之前的 4 字节直接涨到了 16 字节;int 不再能满足需求,为了可以统一处理这两种类型的 IP 现在推荐使用 varchar 来保存。
inet_aton 与 inet_ntoa
这一对 IP 是 IPv4 时代的转换函数,目前来看已经过时。
1、inet_aton IP 转数字。
In [4]: socket.inet_aton("127.0.0.1")
Out[4]: b'\x7f\x00\x00\x01'
2、inet_ntoa 数字转 IP。
In [5]: socket.inet_ntoa(b'\x7f\x00\x00\x01')
Out[5]: '127.0.0.1'
inet_pton 与 inet_ntop
这是一对新的 API ,这对 API 兼容了 IPv4 和 IPv6 。
In [6]: socket.inet_pton(socket.AF_INET6,"5aef:2b::8")
Out[6]: b'Z\xef\x00+\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x08'
In [7]: socket.inet_ntop(socket.AF_INET6,b'Z\xef\x00+\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x08')
Out[7]: '5aef:2b::8'
In [8]: socket.inet_pton(socket.AF_INET,"127.0.0.1")
Out[8]: b'\x7f\x00\x00\x01'
In [9]: socket.inet_ntop(socket.AF_INET,b'\x7f\x00\x00\x01')
Out[9]: '127.0.0.1'
来源:https://www.sqlpy.com/blogs/73116471


猜你喜欢
- 前言:今天和大家分享自己总结的6个常用的Pandas数据处理代码,对于经常处理数据的coder最好熟练掌握。选取有空值的行在观察数据结构时,
- 回调函数定义回调函数是把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,就说这是回调函数。eg:js接口回
- 使用 Microsoft® SQL Server™ 2000,可以选择在一台计算机上安装 SQL Ser
- demo中的p中的script改大或改小看看。。。移动到top的时间始终是一定的,你也可以设置一个阀值,在页面高度到达这个阀值之前,移动的总
- 本文实例讲述了Python数据预处理之数据规范化。分享给大家供大家参考,具体如下:数据规范化为了消除指标之间的量纲和取值范围差异的影响,需要
- 1、闭包的概念请大家跟我理解一下,如果在一个函数的内部定义了另一个函数,外部的我们叫他外函数,内部的我们叫他内函数。闭包: 在一个外函数中定
- docs = [‘icassp improved human face identification using frequency dom
- 作用collate_fn:即用于collate的function,用于整理数据的函数。说到整理数据,你当然要会用数据,即会用数据制作工具to
- 自动换行问题,正常字符的换行是比较合理的,而连续的数字和英文字符常常将容器撑大,挺让人头疼,下面介绍的是CSS如何实现换行的方法对于div,
- 工作中最常见的配置文件有四种:普通key=value的配置文件、Json格式的配置文件、HTML格式的配置文件以及YMAML配置文件。这其中
- 傅立叶级数的介绍我就不说了,自己也是应用为主,之前一直觉得很难懂,但最近通过自己编程实现了一些函数的傅立叶级数展开之后对傅立叶 级数展开的概
- 其实网上已经有许多python语言书写的串口,但大部分都是python2写的,没有找到一个合适的python编写的串口助手,只能自己来写一个
- 一、概述在一般的sql操作中,sql语句基本上都是固定的,如: SELECT t.empno,t.ename FROM scott
- 一般情况下,mysql会默认提供多种存储引擎,可以通过下面的查看:1)查看mysql是否安装了innodb插件。通过下面的命令结果可知,已经
- asp压缩access数据库(带密码)方法:以下是一个类文件,下面的注解是调用类的方法 注意:如果系统不支持建立Scripting
- 介绍godep是解决包依赖的管理工具,目前最主流的一种,原理是扫描记录版本控制的信息,并在go命令前加壳来做到依赖管理godep 建议在 g
- 目前在网上搜到的利用 PyCharm 调试远程服务器程序的教程大多都是针对 PyCharm 2020、2019,甚至更早版本,PyCharm
- Python生产者消费者模型一、消费模式生产者消费者模式 是Controlnet网络 * 有的一种传输数据的模式。用于两个CPU之间传输数据,
- 目录前言总结:1.代码块的缓存机制2.小数据池3.优缺点小整数对象池大整数对象池字符串驻留机制简单原理:前言本文除"总结"
- 事件是什么 ?JavaScript与HTML交互是通过在用户或浏览器操纵页面上发生的事件进行处理。当页面加载,这是一个事件。当用