Select method in List Collection

后端 未结 5 1634
温柔的废话
温柔的废话 2021-01-30 15:57

I have an asp.net application, and now I am using datasets for data manipulation. I recently started to convert this dataset to a List collection. But, in some places it doesn\'

相关标签:
5条回答
  • 2021-01-30 16:31

    Generic List<T> have the Where<T>(Func<T, Boolean>) extension method that can be used to filter data.

    In your case with a row array:

    var rows = rowsArray.Where(row => row["LastName"].ToString().StartsWith("a"));
    

    If you are using DataRowCollection, you need to cast it first.

    var rows = dataTableRows.Cast<DataRow>().Where(row => row["LastName"].ToString().StartsWith("a"));
    
    0 讨论(0)
  • 2021-01-30 16:37

    Well, to start with List<T> does have the FindAll and ConvertAll methods - but the more idiomatic, modern approach is to use LINQ:

    // Find all the people older than 30
    var query1 = list.Where(person => person.Age > 30);
    
    // Find each person's name
    var query2 = list.Select(person => person.Name);
    

    You'll need a using directive in your file to make this work:

    using System.Linq;
    

    Note that these don't use strings to express predicates and projects - they use delegates, usually created from lambda expressions as above.

    If lambda expressions and LINQ are new to you, I would suggest you get a book covering LINQ first, such as LINQ in Action, Pro LINQ, C# 4 in a Nutshell or my own C# in Depth. You certainly can learn LINQ just from web tutorials, but I think it's such an important technology, it's worth taking the time to learn it thoroughly.

    0 讨论(0)
  • 2021-01-30 16:37

    you can also try

    var query = from p in list
                where p.Age > 18
                select p;
    
    0 讨论(0)
  • 2021-01-30 16:40

    I have used a script but to make a join, maybe I can help you

    string Email = String.Join(", ", Emails.Where(i => i.Email != "").Select(i => i.Email).Distinct());
    
    0 讨论(0)
  • 2021-01-30 16:42

    Try this:

    using System.Data.Linq;
    var result = from i in list
                 where i.age > 45
                 select i;
    

    Using lambda expression please use this Statement:

    var result = list.where(i => i.age > 45);
    
    0 讨论(0)
提交回复
热议问题