我们经常需要读取一些如下的属性文件,然后把他们放到一个Dictionary里面。
Name = Dawei XU
Email = dawei.xu@gmail.com
在C#中可以用Linq很方便的实现这个功能。先看代码:
File.ReadAllLines(fileName)
.Select(line => line.Split(new[] {'='}, 2, StringSplitOptions.RemoveEmptyEntries))
.Where(split => split.Length == 2)
.ToDictionary(split => split[0].Trim(), split => split[1].Trim());
用到了如下Linq扩展方法:
- Enumerable.Select ,用来对每一行做split操作,分隔出Key和Value。注意这里要写上分隔成两段。另外要
StringSplitOptions.RemoveEmptyEntries
。 - Enumerable.Where ,用来过滤到不符合Key-Value的行。
- Enumerable.ToDictionary ,把分隔成两段的第一段作为Key,第二个作为Value存在Dictionary里面。
但是这个做法有一个潜在的问题,就是如果属性文件中有重复的Key出现,比如:
Email = dawei.xu@hotmail.com
Name = Dawei XU
Email = dawei.xu@gmail.com
就会抛出 ArgumentException
An element with the same key already exists in the Dictionary .
解决办法就是用 Enumerable.GroupBy 把重复的Key合并在一起,然后可以根据需要使用第一次出现的或者最后一次出现的,下面的例子是采用最后一次出现的。同时因为用了 GroupBy
,最后的 ToDictionary
需要做一些相应的修改。
File.ReadAllLines(fileName)
.Select(line => line.Split(new[] {'='}, 2, StringSplitOptions.RemoveEmptyEntries))
.Where(split => split.Length == 2)
.GroupBy(split=>split[0].Trim())
.ToDictionary(group => group.Key.Trim(), group => group.Last().Last().Trim());
标签:
LINQ
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!