LINQ(五) ——使用LINQ进行匿名对象初始化

总目录
C# 语法总目录
上一篇:LINQ(四) ------使用LINQ进行对象类型初始化

LINQ 五 ------使用LINQ进行匿名对象初始化

    • [6.2 匿名类型](#6.2 匿名类型)

6.2 匿名类型

可以不用声明定义一个对象,直接使用new,然后直接赋值即可

csharp 复制代码
string[] names = { "Tom", "Jerry", "kate", "Lucy", "Micky", "li" };

var query =
    from n in names
    select new
    {
        name = n,
        liName = n.ToLower()
    };

foreach (var item in query)
{
    Console.WriteLine(item.liName+","+item.name);
}

Console.WriteLine("--------------");

IEnumerable<string> strName =
    from n in query
    where n.name.Length > 2
    orderby n.name.Length descending
    select n.name + "," + n.liName;

foreach (var item in strName)
{
    Console.WriteLine(item);
}
//输出
tom,Tom
jerry,Jerry
kate,kate
lucy,Lucy
micky,Micky
li,li
--------------
Jerry,jerry
Micky,micky
kate,kate
Lucy,lucy
Tom,tom

使用两个数组,分别取出两个数组元素的索引,进行比较,然后拼接成一个匿名对象,进行输出。

csharp 复制代码
string[] names = { "Tom", "Jerry", "kate", "Lucy", "Micky", "li" ,"zh"};
int[] ages = { 10, 20, 50, 12, 45, 20 };

var indexedItems = names.Select((value, index) => new { Index = index, Value = value });

var dicar =
    from n in names.Select((value, index) => new { Index = index, Value = value })
    join a in ages.Select((value, index) => new { Index = index, Value = value }) on n.Index equals a.Index
    select new
    {
        name = n.Value,
        age = a.Value
    };

foreach (var item in dicar)
{
    Console.WriteLine($"{item.name},{item.age}");
}
//输出
Tom,10
Jerry,20
kate,50
Lucy,12
Micky,45
li,20

总目录
C# 语法总目录
上一篇:LINQ(四) ------使用LINQ进行对象类型初始化

相关推荐
Iotfsd38 分钟前
.NET写的开源工业物联网网关(IoTGateway)
物联网·c#·.net·dotnet·边缘网关·雾计算·工业物联网智能网关
先生沉默先1 小时前
c#接口_抽象类_多态学习
开发语言·学习·c#
江沉晚呤时1 小时前
深入了解C# List集合及两种常见排序算法:插入排序与堆排序
windows·sql·算法·oracle·c#·排序算法·mybatis
iReachers1 小时前
使用命令行加密混淆C#程序
开发语言·c#
[太阳]882 小时前
Kafka命令行的使用/Spark-Streaming核心编程(二)
c#·linq
电商api接口开发14 小时前
ASP.NET MVC 入门指南
c#·asp.net·mvc
我不是程序猿儿15 小时前
[C#]反射的实战应用,实际数据模拟
开发语言·c#
爱编程的鱼16 小时前
C# 结构(Struct)
开发语言·人工智能·算法·c#
是阿根16 小时前
unity使用iTextSharp生成PDF文件
unity·c#·游戏引擎
ABAP 成17 小时前
.NET Framework 4.0可用EXCEL导入至DataTable
c#