• Linq 中的Select事例


    ---恢复内容开始---

    1.对查询结果进行转换。

    string[] names={"ADE","Jerry","Steves"};
    var ns=from s in names
                where  s.StartWiths("A")
                Select   s.ToLower();
    foreare(var o  in na){
            Console.WriteLine(o);
    }  

    2. 对于数组,select可以对数组元素以及索引进行操作:

      string[] names = { "Jack", "Bob", "Bill", "Catty", "Willam" };
      var rs = names.Select((name, index) => new { Name = name, Index = index });
      foreach (var r in rs)
          Console.WriteLine(r);

    3. 对于集合(wpf中的mvvm为例子),查询选中项是否符合要求:

    private const string LMPPropertyName="LMPSource";
    private OberservableCollection<YM_LMP_SQB> _LMPSource;
    public  OberservableCollection<YM_LMP_SQB>  LMPSource{
    
    get{return _LMPSource;}
    set{
    if(_LMPSource==value)
         return;
    RaisePropertyChanging(LMPPropertyName);
    _LMPSource==value;
    RaisePropertyChanged(LMPPropertyName);
    
    }
    }
    
    int a=LMPSource.Select(
    (s,index)=>new{s,index}).FirstOrDefault(w=w.s==LMPSource.Where(e=>e.ZT!="0").FirstOrDefault()).index+1;
    Console.WriteLine(a)

    4. 组合查询,可以对多个数据源进行组合条件查询(相当于使用SelectMany函数),下面的例子其实就相对于一个双重循环遍历:

        int[] numbersA = { 0, 2, 4, 5, 6, 8, 9 };
        int[] numbersB = { 1, 3, 5, 7, 8 };
    
        var pairs =
            from a in numbersA,
                    b in numbersB
            where a < b
            select new {a, b};
    
        Console.WriteLine("Pairs where a < b:");
        foreach (var pair in pairs)
            Console.WriteLine("{0} is less than {1}", pair.a, pair.b);

    ---恢复内容结束---

  • 相关阅读:
    学习opencv跟轮廓相关的
    opencv 连通域需要的函数解析
    【7.4】__new__和__init__的区别
    【7.3】属性描述符和属性查找过程
    【7.2】__getattr__、__getattribute__魔法函数
    【7.1】property动态属性
    【6.4】一个经典的参数错误
    【6.3】del语句和垃圾回收
    【6.2】==和is的区别
    【6.1】python中的变量是什么
  • 原文地址:https://www.cnblogs.com/mancomeon/p/4933067.html
Copyright © 2020-2023  润新知