首页 > 后端开发 > C++ > 如何在 LINQ 中使用数字后缀实现字母数字排序?

如何在 LINQ 中使用数字后缀实现字母数字排序?

Patricia Arquette
发布: 2024-12-29 01:29:11
原创
434 人浏览过

How Can I Achieve Alphanumeric Ordering in LINQ with Numeric Suffixes?

LINQ 中的字母数字排序

在 LINQ 中,OrderBy 方法遵循字典顺序规则,该规则按顺序考虑字母和数字字符。但是,当对以数值结尾的字符串进行排序时,这种排序可能不会产生所需的结果。

考虑以下示例:

string[] partNumbers = { "ABC10", "ABC1", "ABC2", "ABC11", "ABC10", "AB1", "AB2", "Ab11" };
var result = partNumbers.OrderBy(x => x);
登录后复制

实际结果,按照字典顺序,将是:

AB1
Ab11
AB2
ABC1
ABC10
ABC10
ABC11
ABC2
登录后复制

但是,预期结果是将相似的字母顺序分组在一起,无论数字如何 后缀。为此,我们需要修改排序标准。

按字母数字排序的关键是比较填充的数字部分。通过向数值填充零,我们确保 LINQ 可以正确区分它们。我们可以这样做:

public static string PadNumbers(string input)
{
    return Regex.Replace(input, "[0-9]+", match => match.Value.PadLeft(10, '0'));
}
登录后复制

此函数将零填充到输入字符串中的任何数字。通过使用此函数作为 LINQ 中的排序标准,我们得到了预期的结果:

var result = partNumbers.OrderBy(x => PadNumbers(x));
登录后复制

结果列表现在将排序为:

AB1
AB2
AB11
...
登录后复制

此方法假设最大数字部分的位数是已知的。对于更复杂的情况,请考虑实现自定义 IComparer,它允许对比较标准进行更细粒度的控制。

以上是如何在 LINQ 中使用数字后缀实现字母数字排序?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板