2 个列表的嵌套 LINQ 查询
本文关键字:LINQ 查询 嵌套 列表 | 更新日期: 2023-09-27 18:37:10
我需要使用嵌套的linq查询来查找匹配的字符串。
我目前有 2 个带有字符串的列表,一个包含所有字符串,另一个只有 3 个。我已经尝试了很多选择,但我只是不明白这些是如何工作的。
这可能是一个非常容易的错误,但我仍然是 C# 的新手,我每天都在学习。
这就是我走多远,但我被困在松散的跟踪错误上。
public static void printTracks()
{
List<string> allTracks = new List<string>();
//This list is filled with strings (Track titles)
List<string> looseTracks = new List<string>();
Track track1 = new Track("Smells Like Teen Spirit", "Nirvana", "00:05:02");
Track track2 = new Track("Come as You Are", "Nirvana", "00:03:38");
Track track3 = new Track("Lithium", "Nirvana", "00:04:16");
looseTracks.Add(track1.title);
looseTracks.Add(track2.title);
looseTracks.Add(track3.title);
var query = from tr1 in allTracks
from tr2 in tr1.looseTracks //Error!
where tr1.Equals(tr2)
select tr1;
foreach (string s in query)
{
Console.WriteLine(s);
}
}
错误给了我这个:
错误 1 'string' 不包含 'looseTracks'的定义,并且找不到接受类型为 'string' 的第一个参数的扩展方法 'looseTracks' (您是否缺少 using 指令或程序集引用?C:''Users''Gebruiker''Desktop''workspace Visual Studio 2013''Practicum 4''Program.cs 104 45 Practicum 4
我必须使用嵌套查询,但我只是不知道如何。有人可以帮助我吗?
如果我忘记了什么,或者这不起作用,请告诉我!提前感谢!
我想
你想做类似的事情。
var query = from tr1 in allTracks
where looseTracks.Contains(tr1.title)
select tr1;
或者只是方法语法中的以下内容。
var query = allTracks.Where(tr1 => looseTracks.Contains(tr1.title));
这是假设allTracks
是List<Track>
,looseTracks
是List<string>
。
//Just imagine this list being filled with 'Track' objects
我会把它想象成没有被"跟踪"对象填充。您将其定义为字符串列表,而不是曲目列表。
List<Track> allTracks = new List<Track>();
List<Track> looseTracks = new List<Track>();