V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
MiaRunis
V2EX  ›  问与答

有没有什么工具能把一大堆 ip 自动合并成 CIDR /24 /16 的格式?

  •  
  •   MiaRunis · 2020-04-04 11:33:47 +08:00 · 2487 次点击
    这是一个创建于 1454 天前的主题,其中的信息可能已经有所发展或是发生改变。
    RT

    比如收集到几千个 ip,但路由并不需要精确到每一个,只需要 xxx.xxx.xxx.0-255 这样 /24 精度即可。

    有没有什么现成工具能合并生成 CIDR 列表?
    14 条回复    2022-02-18 09:55:06 +08:00
    hiplon
        1
    hiplon  
       2020-04-04 11:35:14 +08:00
    排个序找到最大最小就很好算了
    ihciah
        2
    ihciah  
       2020-04-04 11:43:06 +08:00 via iPhone
    先转成 /24,再用开源工具合并?
    gstqc
        3
    gstqc  
       2020-04-04 11:58:20 +08:00 via Android   ❤️ 1
    把最后一位替换成 0/24,然后去重
    Livid
        4
    Livid  
    MOD
       2020-04-04 12:15:07 +08:00 via iPhone   ❤️ 7
    变成十进制,然后减去 % 256 的结果放进一个 set,最后 set 里的数字转回 IP 就是所有的 /24
    samuel
        5
    samuel  
       2020-04-04 12:37:16 +08:00
    #! python3
    import struct
    import socket
    import sys

    cidr = set()
    mask = int('0xFFFFFF00', 16)

    for line in sys.stdin:
    b = struct.unpack('!I', socket.inet_aton(line))[0]
    cidr.add(b & mask)

    for c in cidr:
    print(socket.inet_ntoa(struct.pack("!I", c)) + '/24')
    V69EX
        6
    V69EX  
       2020-04-04 12:50:08 +08:00
    @samuel 楼主提 CIDR 的意思,我觉得应该是可变长的掩码,不是固定的 /24,固定长度的掩码,就没必要提 CIDR 了……
    ladeo
        7
    ladeo  
       2020-04-04 12:50:10 +08:00 via Android
    excel 就可以了吧
    xiadong1994
        8
    xiadong1994  
       2020-04-04 12:53:46 +08:00 via iPhone
    最长公共前缀子串
    also24
        9
    also24  
       2020-04-04 12:58:00 +08:00
    @V69EX #6
    楼主在帖子里不是说只需要 /24 即可嘛?
    Akkuman
        10
    Akkuman  
       2020-04-04 13:46:59 +08:00 via Android
    @Livid 好方法
    webshe11
        11
    webshe11  
       2020-04-04 14:02:44 +08:00
    看着跟 CCF 认证 201812-3 题 CIDR 合并 一样
    http://118.190.20.162/view.page?gpid=T82
    RickyHao
        12
    RickyHao  
       2020-04-04 14:23:58 +08:00 via Android   ❤️ 1
    import netaddr
    cidr_list = netaddr.cidr_merge(ip_list)
    Laynooor
        13
    Laynooor  
       2020-04-04 14:34:17 +08:00
    apt install aggregate
    yum install aggregate
    matrix67
        14
    matrix67  
       2022-02-18 09:55:06 +08:00
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   994 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 20:00 · PVG 04:00 · LAX 13:00 · JFK 16:00
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.