Linq 查询 - 根据第一个字母 b/w 两个范围查找字符串

Posted

技术标签:

【中文标题】Linq 查询 - 根据第一个字母 b/w 两个范围查找字符串【英文标题】:Linq query - find strings based upon first letter b/w two ranges 【发布时间】:2011-11-05 05:21:51 【问题描述】:

我们有一个包含国家名称的列表。我们需要从黑白两个字母的列表中找到国家/地区的名称。就像所有国家的名称一样,名称以黑白 A-G 开头,依此类推。我们创建了以下 linq 查询,但它很难看。

var countryAG = from elements in countryList
where elements.StartsWith("A") || 
elements.StartsWith("B") || 
elements.StartsWith("C") || 
elements.StartsWith("D") || 
elements.StartsWith("E") || 
elements.StartsWith("F") || 
elements.StartsWith("G") || 
elements.StartsWith("H") 
select elements;

countryList 在 C# 中的创建位置

List< string> countryList = new List< string>();

任何帮助或任何其他有效的方式来完成上述任务?

【问题讨论】:

我们可以假设国家名称是英文的,我们可以使用英文排序吗? 【参考方案1】:
var countryAG = from elements in countryList
                where elements[0] >= 'A' && elements[0] <= 'H'
                select elements;

字符实际上只是数字,因此您可以这样比较它们

【讨论】:

那个查询不会编译,你忘了select 感谢@Steven,但在构建过程中出现以下错误:查询正文必须以 select 子句或 group 子句结尾 @svick,我应该在哪里添加选择? 工作就像一个魅力。谢谢@Steven。 工作就像一个魅力。感谢@svick 的所有帮助。【参考方案2】:

我现在无法测试,但我会尝试

countryList.Where((s) => s[0] <= 'A' && s[0] >= 'G');

【讨论】:

【参考方案3】:

您可以使用前缀列表,然后使用前缀列表进行比较 - 这样您就可以根据您感兴趣的范围轻松使用不同的前缀列表:

 List<string> prefixList = new List<string>()  "A", "B", "C", "D", "E", "F", "G" ;
 var countryAG = countryList.Where( x=> prefixList.Any( p => x.StartsWith(p)));

【讨论】:

感谢@Broken,但这与我目前的方法相同。我对写所有英文字母不感兴趣。【参考方案4】:

试试

char[] startingLetters = new char[] 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H';
var countryAG = 
    from elements in countryList 
    where elements.IndexOfAny(startingLetters, 0, 1) == 0 
    select elements;

有关IndexOfAny 的信息,请参阅here。

【讨论】:

感谢@Yahia,但这与我目前的方法相同。我对写所有英文字母不感兴趣。 很抱歉,您要求一种更有效的方法...我敢打赌,我的答案中的查询比您当前使用的查询运行得更快,因此我建议它... 对不起@Yahia。我在构建“让事情变得简单”时忽略了效率方面,而忽略了“高效”部分。再次抱歉。另外,我们有没有办法“让事情变得简单高效”。场景很简单,我们有国家名称列表,我们必须将它们划分为 A-G、I-P 和 Q-Z。我认为 Linq 又快又容易。请提出您的想法。【参考方案5】:

尝试使用此代码:

var start = "a";
var end = "g";
var regex = new Regex(string.Format("^[0-1]", start, end));
var result = list.Where(x => regex.Match(x.ToLowerInvariant()).Success);

'start' 和 'end' 以静态为例。

【讨论】:

使用正则表达式听起来很有趣。我会试试这个。感谢您的回复。 你可以使用Match().Success,而不是IsMatch()【参考方案6】:

我有两个扩展函数:

public static IEnumerable<char> Range(char start, char end)

  return Enumerable.Range((int)start, (int)end - (int)start + 1).Select(i => (char)i);

创建一系列字符,并且

public static bool In(this string source, IEnumerable<string> collection)

  return collection.Contains(source);

这与Contains 正好相反,主要是为了可读性。

我可以一起做:

where elements[0].In(Range('a', 'f')))

【讨论】:

以上是关于Linq 查询 - 根据第一个字母 b/w 两个范围查找字符串的主要内容,如果未能解决你的问题,请参考以下文章

如何让LINQ根据文化订购?

LINQ查询表达式 - LINQ 查询分组

30.第一个Linq 数据库查询

使用 LINQ 查询语法 EF Core C# 的左外连接

Linq------各种查询语句大全

如何使用LINQ返回多个自选字段