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

我必须使用嵌套查询,但我只是不知道如何。有人可以帮助我吗?

如果我忘记了什么,或者这不起作用,请告诉我!提前感谢!

2 个列表的嵌套 LINQ 查询

我想

你想做类似的事情。

var query = from tr1 in allTracks
            where looseTracks.Contains(tr1.title)
            select tr1;

或者只是方法语法中的以下内容。

var query = allTracks.Where(tr1 => looseTracks.Contains(tr1.title));

这是假设allTracksList<Track>looseTracksList<string>

//Just imagine this list being filled with 'Track' objects

我会把它想象成没有被"跟踪"对象填充。您将其定义为字符串列表,而不是曲目列表。

List<Track> allTracks = new List<Track>();
List<Track> looseTracks = new List<Track>();