LINQ(4)——Linq To Object

查询语句:

 int[] values = { 30, 5, 99, 77, 102, 8, 12, 35 };
            var result = from item in values //foreach(int item in values)
                         where item > 20
                         select item;

和sql语句不同,linq中select放到最后(方便类型推断)。in后是要进行处理的集合,from后的变量是values中每个元素的变量(联想foreach),select后是查询结果,result是select结果变量类型的泛型的IEnumerable,注意是泛型的IEnumerable 。linq关键时刻能救人一命。

练习:

1、从字符串数组中将长度小于5的元素返回;

2、一个字符串数组中所有元素都是整数的表示形式,将他们中大于100的以int序列返回;{"1","25","250","388","99"}

3、将一个姓名为Key、年龄为value的Dictionary中年龄大于20的人的姓名用“,”分割打印出来。//ToArray(),Join

4、将 "ajax,javascript,jquery"字段中的单词加上【】输出出来。select “[”+item+”]”

5、一个Dictionary<string,int>中是key为姓名,value为年龄的数据,将其中年龄大于20的人依次输出到含有Name、Age属性的匿名类型的序列中。select new {}

6、一个Dictionary<string,int>中是key为姓名,value为年龄的数据,将其中年龄大于20的人输出到含有Name、Age属性的预定义类型Person的序列中。

int[] values = { 3, 5, 9, 8, 2, 20, -5, -9, 306 };
            values.OrderBy(i => i);
            //过滤掉负数,把数组排序,然后元素两边加[]输出
            IEnumerable<int> e1= values.Where(i => i > 0);
            var e1 = values.Where(i => i > 0);
            foreach (int i in e1)
            {
                Console.WriteLine(i);
            }

            //=========================进化=========

            var e1 = values.Where(i => i > 0).OrderBy(i => i)
                .Select(i=>"["+i+"]");
            foreach (var i in e1)
            {
                Console.WriteLine(i);
            }

            //================进化:微软V5,效率更高更清晰=========
            //
            //执行顺序是从上到下
            var e1 = from i in values//foreach(int i in values)
                     where i>0
                     orderby i descending
                     select "[" + i + "]";
            //基于类型推断的考虑,select在最后,from在最前
            foreach (var i in e1)
            {
                Console.WriteLine(i);
            }

            //根据一个DBPerson对象,过滤出年龄大于20的人,按照年龄排序
            //并且根据FirstName、LastName拼出Name

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值