C# Language SelectMany: appiattimento di una sequenza di sequenze


Esempio

var sequenceOfSequences = new [] { new [] { 1, 2, 3 }, new [] { 4, 5 }, new [] { 6 } };
var sequence = sequenceOfSequences.SelectMany(x => x);
// returns { 1, 2, 3, 4, 5, 6 }

Utilizzare SelectMany() se si dispone, o si sta creando una sequenza di sequenze, ma si desidera il risultato come una lunga sequenza.

In LINQ Query Sintassi:

var sequence = from subSequence in sequenceOfSequences
               from item in subSequence
               select item;

Se si dispone di una raccolta di raccolte e si desidera poter lavorare contemporaneamente ai dati dalla raccolta padre e figlio, è anche possibile con SelectMany .

Definiamo classi semplici

public class BlogPost
{
    public int Id { get; set; }
    public string Content { get; set; }
    public List<Comment> Comments { get; set; }
}

public class Comment
{
    public int Id { get; set; }
    public string Content { get; set; }
}

Supponiamo di avere la seguente collezione.

List<BlogPost> posts = new List<BlogPost>()
{
    new BlogPost()
    {
        Id = 1,
        Comments = new List<Comment>()
        {
            new Comment()
            {
                Id = 1,
                Content = "It's really great!",
            },
            new Comment()
            {
                Id = 2,
                Content = "Cool post!"
            }
        }
    },
    new BlogPost()
    {
        Id = 2,
        Comments = new List<Comment>()
        {
            new Comment()
            {
                Id = 3,
                Content = "I don't think you're right",
            },
            new Comment()
            {
                Id = 4,
                Content = "This post is a complete nonsense"
            }
        }
    }
};

Ora vogliamo selezionare i commenti Content con Id di BlogPost associata a questo commento. Per fare ciò, possiamo usare il sovraccarico SelectMany appropriato.

var commentsWithIds = posts.SelectMany(p => p.Comments, (post, comment) => new { PostId = post.Id, CommentContent = comment.Content });

I nostri commentsWithIds assomiglia a questo

{
    PostId = 1,
    CommentContent = "It's really great!"
},
{
    PostId = 1,
    CommentContent = "Cool post!"
},
{
    PostId = 2,
    CommentContent = "I don't think you're right"
},
{
    PostId = 2,
    CommentContent = "This post is a complete nonsense"
}