Linq的筛选、排序等几种用法(VS2010)

1.首先需要一个集合用来测试:

 //定义一个集合要用的类:

 public class People
  {
            public People(string name, string sex, int age,decimal height)
            {
                this.Name = name;
                this.Sex = sex;
                this.Age = age;
                this.Height = height;
            }

            public string Name { get; set; }
            public string Sex { get; set; }
            public int Age { get; set; }

            public decimal Height { get; set; }

            public string ToString(string format)
            {
                return ToString(format);
            }

}

 //制造几条测试数据:

 List<People> list = new List<People>();
 list.Add(new People("ymw", "男", 22, 170m));
 list.Add(new People("Lily", "女", 21, 160m));
 list.Add(new People("xj", "女", 20, 158m));
 list.Add(new People("Lucy", "女", 23, 166m));
 list.Add(new People("MM", "女", 18, 168m));

 

 2.Linq特性示例一:

            //筛选
            List<People> lists = list.FindAll(
                 delegate(People p)
                 {
                     return p.Sex == "女";
                 });

             //排序(根据类型)
             lists.Sort(
                 delegate(People p1, People p2)
                 {
                     return p1.Name.CompareTo(p2.Name);
                 });

             foreach (People item in lists)
             {
                 this.txt.Text += item.Name + "~" + item.Age + "~" + item.Sex+"~"+item.Height + "\r\n";
             }

 //如图测试结果:过滤了性别为男的人并按照名称排序↓

 

3.Linq特性示例二:

 //Where、Select、OrderByDescending 用法:Where、Select用来帅选过滤;OrderByDescending是按降序排列

 IEnumerable<People> lists = list.Where(
                delegate(People p)
                {
                    return p.Sex == "女";
                }).OrderByDescending( //OrderBy
                delegate(People p)
                {
                    return p.Height;
                }).Select(
                delegate(People p)
                {
                    return p;
                });
            foreach (People item in lists)
            {
                this.txt.Text += item.Name + "~" + item.Age + "~" + item.Sex + "~" + item.Height + "\r\n";
            }

// var lists2 = list.Where(p => p.Sex == "女" || p.Sex == "男").OrderBy(p => p.Height).Select(p => p);

//如图测试结果:过滤了性别为男的人并按照身高降序排序↓

4.Linq特性示例三:

// λ表达式
 IEnumerable<People> lists = list.Where(p => p.Sex == "女").OrderByDescending(p => p.Height).Select(p => p);

 foreach (People item in lists)
  {
         this.txt.Text += item.Name + "~" + item.Age + "~" + item.Sex + "~" + item.Height + "\r\n";
  }

//测试结果如上图实例二:过滤了性别为男的人并按照身高降序排序↓

 

5.Linq特性示例四:

var lists = (from p in list
                         where p.Sex == "女"
                         orderby p.Age ascending, p.Height
                         select p).Take(4); //Take()取前几条记录

  foreach (People item in lists)
  {
          this.txt.Text += item.Name + "~" + item.Age + "~" + item.Sex + "~" + item.Height + "\r\n";
   }

//测试结果如下图,按年龄排序且取前四条记录↓

posted @   _YMW  阅读(4377)  评论(1编辑  收藏  举报
努力加载评论中...
点击右上角即可分享
微信分享提示