LInq之Take Skip TakeWhile SkipWhile Reverse Union Concat 用法

简介: 废话不多说,直接上代码,代码有注释!自行运行测试! class Program { static void Main(string[] args) { string[] names = { "郭靖", "李莫愁", "欧阳晓晓", "黄蓉", "黄药师", "郭靖", "黄蓉" }; //Take()方法:用于从一个序列的开头返回指定数量的元素。

废话不多说,直接上代码,代码有注释!自行运行测试!

    class Program
    { 
        static void Main(string[] args)
        {
            string[] names = { "郭靖", "李莫愁", "欧阳晓晓", "黄蓉", "黄药师", "郭靖", "黄蓉" };

            //Take()方法:用于从一个序列的开头返回指定数量的元素。 
            Console.WriteLine("Take方法直接输出前3个元素");
            foreach (var name in names.Take(3))
            {
                Console.WriteLine(name);
            }
            var query = from n in names
                        where n.Length == 2
                        select n;
            Console.WriteLine("Take方法输出查询结果的前1个元素");
            foreach (var s in query.Take(1))
            {
                Console.WriteLine(s);
            }
            Console.WriteLine("\n\n\n");
            ///////////////////////////////////////////////////////////////////////
            //Skip()方法:用于跳过序列中指定个数的元素。
            //////////////////////////////////////////////////////////////////////
            Console.WriteLine("Skip方法跳过前3个元素");
            foreach (var name in names.Skip(3))
            {
                Console.WriteLine(name);
            }
            Console.WriteLine("Skip方法跳过查询结果的前1个元素");
            foreach (var s in query.Skip(1))
            {
                Console.WriteLine(s);
            }
            Console.WriteLine("\n\n\n");
            ///////////////////////////////////////////////////////////////////////
            //TakeWhile()方法:用于取序列中从开头起符合条件的元素,直到遇到不符合条件的元素为止的所有元素。注意:当条件为假时,就停止了,后面的元素不会输出。
            //////////////////////////////////////////////////////////////////////
            Console.WriteLine("TakeWhile用法1如下");
            foreach (var name in names.TakeWhile(A=>A.Length==2))
            {
                Console.WriteLine(name);
            }
            Console.WriteLine("TakeWhile用法2如下");
            //注意:当条件为假时,就停止了,后面的元素不会输出。 
            foreach (var name in names.TakeWhile((item, index) => item.Length < 4 && index < 4))
            {
                Console.WriteLine(name);
            }
            Console.WriteLine("\n\n\n");
            ///////////////////////////////////////////////////////////////////////
            //SkipWhile()方法:用于只要满足指定的条件,就跳过序列中得元素。注意:当遇到条件为假时,就停止跳越了,输出剩余的所有元素。
            //////////////////////////////////////////////////////////////////////
            Console.WriteLine("SkipWhile用法1如下");
            foreach (var name in names.SkipWhile(n => n.Length == 2))
            {
                Console.WriteLine(name);
            }
            Console.WriteLine("SkipWhile用法2如下");
            //SkipWhile跳过名字小于4个字,并且索引小于2
            foreach (var s in names.SkipWhile((item, index) => item.Length < 4 && index < 2))
            {
                Console.WriteLine(s);
            }
            Console.WriteLine("\n\n\n");
            ///////////////////////////////////////////////////////////////////////
            //Reverse()方法:用于反转
            //////////////////////////////////////////////////////////////////////
            Console.WriteLine("Reverse用法1如下");
            foreach (var name in names.Reverse())
            {
                Console.WriteLine(name);
            }
            Console.WriteLine("\n\n\n");
            ///////////////////////////////////////////////////////////////////////
            //Distinct()方法:用于去掉重复元素
            //////////////////////////////////////////////////////////////////////
            Console.WriteLine("Distinct用法1如下");
            foreach (var name in names.Distinct())
            {
                Console.WriteLine(name);
            }
            Console.WriteLine("\n\n\n");
            ///////////////////////////////////////////////////////////////////////
            //Union()方法:用于合并两个序列,并去掉重复元素。
            //////////////////////////////////////////////////////////////////////
            Console.WriteLine("Union用法1如下");
            string[] names2 = {  "郭靖", "黄蓉","神雕","小龙女" };
            foreach (var name in names.Union(names2))
            {
                Console.WriteLine(name + " ");
            }
            Console.WriteLine("\n\n\n");
            ///////////////////////////////////////////////////////////////////////
            //Concat()方法:用于合并两个序列,但不会去掉重复元素。
            //////////////////////////////////////////////////////////////////////
            Console.WriteLine("Concat用法1如下");
            foreach (var name in names.Concat(names2))
            {
                Console.WriteLine(name + " ");
            }
            Console.ReadKey();
        }
      
    }

@陈卧龙的博客

相关文章
|
Web App开发 前端开发
ZLMediaKit解决webrtc前端replaceTrack断流问题
ZLMediaKit解决webrtc前端replaceTrack断流问题
|
fastjson 前端开发
巧用fastjson自定义序列化类实现字段的转换
项目中突然需要增加另一个字段的查找,而这个查找需要查另一张表的记录。 但现在产品很多地方都要增加该字段,如何最快的实现该功能呢。 办法如下: 通过fastjson序列化时,增加该字段的序列化类,该序列化类通过CODE查找名称,并序列化到前端。
6074 0
|
SQL 数据库 数据库管理
SQLite数据库操作
【7月更文挑战第31天】SQLite数据库操作
265 6
|
数据库 数据库管理 关系型数据库
|
SQL 数据库 C语言
sqlite3使用入门
本文介绍了SQLite3数据库的安装与使用方法。首先通过`sudo apt install sqlite3`进行安装,并用`sqlite3 --version`验证版本。启动SQLite3后,使用`.help`查看系统维护命令,如`.database`列出数据库、`.tables`列出表等。通过标准SQL语句创建、查询、更新和删除表及数据。示例代码展示了如何使用C语言进行数据库操作,包括打开、创建表、插入数据、查询、更新和删除等基本功能。此外,还介绍了SQLite3的事务处理机制及其重要特性。
|
存储 关系型数据库 分布式数据库
PolarDB的PolarStore存储引擎以其高效的索引结构、优化的数据压缩算法、出色的事务处理能力著称
PolarDB的PolarStore存储引擎以其高效的索引结构、优化的数据压缩算法、出色的事务处理能力著称。本文深入解析PolarStore的内部机制及优化策略,包括合理调整索引、优化数据分布、控制事务规模等,旨在最大化其性能优势,提升数据存储与访问效率。
249 5
|
API 开发工具 计算机视觉
华视 CVR-100UC 身份证读取 Python 二次开发(包含SDK下载地址)
华视 CVR-100UC 身份证读取 Python 二次开发(包含SDK下载地址)
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp的反诈科普平台的详细设计和实现
基于SpringBoot+Vue+uniapp的反诈科普平台的详细设计和实现
394 7
基于SpringBoot+Vue+uniapp的反诈科普平台的详细设计和实现
|
存储 调度 芯片
RT-Thread快速入门-内核移植
RT-Thread快速入门-内核移植
340 0
|
机器学习/深度学习 自然语言处理 算法
分词算法在自然语言处理中的基本原理与应用场景
分词算法在自然语言处理中的基本原理与应用场景