gpt4 book ai didi

c# - 使用 LINQ 过滤列表

转载 作者:IT王子 更新时间:2023-10-29 04:02:34 24 4
gpt4 key购买 nike

我有一个项目对象列表:

IEnumerable<Project> projects

Project 类作为称为Tags 的属性。这是一个int[]

我有一个名为 filteredTags 的变量,它也是一个 int[]

假设我的过滤标签变量看起来像这样:

 int[] filteredTags = new int[]{1, 3};

我想过滤我的列表 (projects) 以仅返回具有过滤器中列出的所有标签的项目(在这种情况下,至少 Tags 中的标签 1 和标签 3 属性)。

我试图使用 Where() 和 Contains() 但这似乎只有在我与单个值进行比较时才有效。我将如何执行此操作以将一个列表与另一个列表进行比较,而我需要对过滤列表中的所有项目进行匹配??

最佳答案

编辑:更好的是,这样做:

var filteredProjects = 
projects.Where(p => filteredTags.All(tag => p.Tags.Contains(tag)));

EDIT2:老实说,我不知道哪个更好,所以如果性能不重要,请选择您认为更具可读性的那个。如果是,则必须以某种方式对其进行基准测试。


可能 Intersect 是要走的路:

void Main()
{
var projects = new List<Project>();
projects.Add(new Project { Name = "Project1", Tags = new int[] { 2, 5, 3, 1 } });
projects.Add(new Project { Name = "Project2", Tags = new int[] { 1, 4, 7 } });
projects.Add(new Project { Name = "Project3", Tags = new int[] { 1, 7, 12, 3 } });

var filteredTags = new int []{ 1, 3 };
var filteredProjects = projects.Where(p => p.Tags.Intersect(filteredTags).Count() == filteredTags.Length);
}


class Project {
public string Name;
public int[] Tags;
}

虽然一开始看起来有点难看。如果您不确定它们在列表中是否都是唯一的,您可以先将 Distinct 应用于 filteredTags,否则计数比较将无法按预期进行。

关于c# - 使用 LINQ 过滤列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5090568/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com