如何对一组 IP 地址 进行排序?

Posted dotNET跨平台

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何对一组 IP 地址 进行排序?相关的知识,希望对你有一定的参考价值。

咨询区

  • Cracker

我有一组如下IP地址。

192.168.1.5
69.52.220.44
10.152.16.23
192.168.3.10
192.168.1.4
192.168.2.1

我在寻找一个方法将他们排序成如下顺序。

10.152.16.23
69.52.220.44
192.168.1.4
192.168.1.5
192.168.2.1

回答区

  • Alex Aza

对 ip 地址进行排序,大概有三种方法。

  1. 使用 Version.Parse

这种方式最简单粗暴,也最有意思,参考代码如下:

static void Main(string[] args)
        
            var unsortedIps = new[]  "192.168.1.4",
                                      "192.168.1.5",
                                      "192.168.2.1",
                                      "10.152.16.23",
                                      "69.52.220.44"
                                     ;

            var sortedIps = unsortedIps
                .Select(Version.Parse)
                .OrderBy(arg => arg)
                .Select(arg => arg.ToString())
                .ToList();

            sortedIps.ForEach(k => Console.WriteLine(k));
        

输出结果:

  1. 将ip转int

字符串ip是无法进行有效排序的,但可以将其转为 int 处理,比如下面这样:

69.52.220.44 =>

69 * 255 * 255 * 255 +
52 * 255 * 255 +
220 * 255 +
44
  1. 3位填充法

先将IP地址切开,然后将不足三位的部分填充 0 ,这样就方便直接对 string 进行排序,最后再拼接起来,参考如下代码:

public static class StringHelper

    public static string IpAddressLabel(string ipAddress)
        => string.Join(".", ipAddress.Split('.').Select(part => part.PadLeft(3, '0')));

接下来简单测试下。

=> new[] "192.168.1.100", "192.168.1.1", "192.168.1.19"
      .OrderBy(ip => StringHelper.IpAddressLabel(ip));

点评区

这三种对 IP 排序的方法有点意思,学习了。

以上是关于如何对一组 IP 地址 进行排序?的主要内容,如果未能解决你的问题,请参考以下文章

如何通过 created_at 对一组行进行排序?

如何一次对一组 200 个地址进行地理编码

C语言链表中如何实现对一组数据进行排序?

rank() 按 count(*) 对一组项目进行排序

在JAVA里,对一组数字进行从小到大排序,是否直接调用类,调用对象方法,直接排就行了。

PHP如何对一组数进行重新排列(冒泡算法)