LinqToObject(2)——自由自在

简介: 对于Linq查询有几个要点,数据源,元素,投影。把握这几个要点,那么运用起来得心应手。  (一)查找句子 这里指的句是是英文句子,英文句子以.!?结束(逗点,叹号,问号)。下面摘取《The Call of the Wild》一段来进行介绍。

对于Linq查询有几个要点,数据源,元素,投影。把握这几个要点,那么运用起来得心应手。

 

(一)查找句子

这里指的句是是英文句子,英文句子以.!?结束(逗点,叹号,问号)。下面摘取《The Call of the Wild》一段来进行介绍。

先来一大段:

string str=@"There he lay for the remainder of the weary night, nursing his wrath"+

@"and wounded pride. He could not understand what it all meant. What"+

@"did they want with him, these strange men? Why were they keeping"+

@"him pent up in this narrow crate? He did not know why, but he felt"+

@"oppressed by the vague sense of impending calamity. Several times"+

@"during the night he sprang to his feet when the shed door rattled open,"+

@"expecting to see the Judge, or the boys at least. But each time it was"+

@"the bulging face of the saloon-keeper that peered in at him by the sickly"+

@"light of a tallow candle. And each time the joyful bark that trembled in"+

@"Buck's throat was twisted into a savage growl.";

 

然后,查找带有“Buck”的句子,并分别打印出来。

首先,这里的数据源就是这个字符串(或者说这个段落),然后元素就是想要的每个句子,投影也是句子,就是要段落中的所有句子。

获取数据源:数据源应该是句子集合,对于字符串来说,直接的进行Linq查询,那么它的元素将是一个一个的字符,所以这里要得到数据源:

string [] sentences = str.Split( new   char []{ ' . ' , ' ? ' , ' ! ' });

 

用来分隔句子。现在的结果是:

 

There he lay for the remainder of the weary night, nursing his wrathand wounded pride

 

 

然后,对于含有“Buck”的句子就是其中的元素,它的类型是字符串;而所需要就是这些句子。

var q1 = from p  in  sentences
        
where  p.Contains( " Buck " )
        select p;

  

 

 

 

上边查出的句子前边有空格,现在去除空格,这里用正则表达式来完成。

这个相对比较简单:

var q1 = from p  in  sentences
        
where  p.Contains( " Buck " )
        select Regex.Replace(p,
@" ^\  " , "" );

  

 

And each time the joyful bark that trembled inBuck's throat was twisted

into a savage growl

(二)遍历文件

遍历目录下的所有文件并打印:

DirectoryInfo path  =   new  DirectoryInfo( @" L:\css " );
FileInfo[] fileinfos 
=  path.GetFiles(); 

var q 
=  from p  in  fileinfos
         elect 
new  { 文件名  =  p.Name, 文件大小  =  p.Length  /   1024  };
q.Dump();

 

我现在打印的是目录下的文件:

 

文件名

文件大小

1.jpg

247

float.htm

0

……

……

链接.htm

0

 

上边只是遍历了目录下的文件,而对于其中的文件夹中的文件没能查询到,下边实现遍历全路径,方法很简单:

DirectoryInfo path  =   new  DirectoryInfo( @" L:\css " );
FileInfo[] fileinfos 
=  path.GetFiles( " * " , SearchOption.AllDirectories); 

var q 
=  from p  in  fileinfos
         select 
new  
       { 文件名 
=  p.Name, 文件大小  =  p.Length  /   1024 , 文件路径  =  p.FullName };

q.Dump();

  

 

文件名

文件大小

文件路径

1.jpg

247

L:\css\1.jpg

float.htm

0

L:\css\float.htm

……

……

……

qq.gif

25

L:\css\pic\qq.gif

t.png

15

L:\css\pic\t.png

 

找到数据源,明确其中的元素单位,并按所需进行投影设置。

 

(三)查找最大的文件

按文件大小排序,并通过元素选择来得到文件

DirectoryInfo path  =   new  DirectoryInfo( @" L:\css " );
FileInfo[] fileinfos 
=  path.GetFiles( " * " , SearchOption.AllDirectories);

var q 
=  (from p  in  fileinfos
          orderby p.Length
          select p).Last();
Console.Write(q.FullName);

 

(四)在文本文件中查找字符串

查找带有指定字符串的文件

var q  =  from p  in  fileinfos
         
where  p.Extension  ==   " .htm "
         select p.FullName;

  

先指定筛选条件文件文件,扩展名为htm的文件,然后投影选择文件全名。然后在投影之前添加对文本文件中的字符串的查找:

DirectoryInfo path  =   new  DirectoryInfo( @" L:\css " );
FileInfo[] files 
=  path.GetFiles( " * " , SearchOption.AllDirectories); 

var q 
=  from p  in  files
        
where  p.Extension  ==   " .htm "
        
&&  GetFileContent(p.FullName).Contains( " 导航 " )
        select p;

foreach  (var info  in  q)
    Console.WriteLine(info.FullName);

  

GetFileContent方法是通过路径读取文本文件内容。

结果略。

这里提一下let关键字。Let类似mssql中的declare,用于声明局部变量

var q  =  from p  in  files
         
where  p.Extension  ==   " .htm "
         let strContent
=  GetFileContent(p.FullName)
         
where  strContent.Contains( " 导航 " )
         select p;

  

这里设置strContent变量,然后再通过另一个where来与上过滤条件。Let非常有用。

 

博客园大道至简

http://www.cnblogs.com/jams742003/

转载请注明:博客园

目录
相关文章
|
7天前
|
NoSQL Cloud Native Redis
Redis核心开发者的新征程:阿里云与Valkey社区的技术融合与创新
阿里云瑶池数据库团队后续将持续参与Valkey社区,如过往在Redis社区一样耕耘,为开源社区作出持续贡献。
Redis核心开发者的新征程:阿里云与Valkey社区的技术融合与创新
|
7天前
|
关系型数据库 分布式数据库 数据库
PolarDB闪电助攻,《香肠派对》百亿好友关系实现毫秒级查询
PolarDB分布式版助力《香肠派对》实现百亿好友关系20万QPS的毫秒级查询。
PolarDB闪电助攻,《香肠派对》百亿好友关系实现毫秒级查询
|
8天前
|
消息中间件 Cloud Native Serverless
RocketMQ 事件驱动:云时代的事件驱动有啥不同?
本文深入探讨了云时代 EDA 的新内涵及它在云时代再次流行的主要驱动力,包括技术驱动力和商业驱动力,随后重点介绍了 RocketMQ 5.0 推出的子产品 EventBridge,并通过几个云时代事件驱动的典型案例,进一步叙述了云时代事件驱动的常见场景和最佳实践。
115060 1
|
9天前
|
弹性计算 安全 API
访问控制(RAM)|云上安全使用AccessKey的最佳实践
集中管控AK/SK的生命周期,可以极大降低AK/SK管理和使用成本,同时通过加密和轮转的方式,保证AK/SK的安全使用,本次分享为您介绍产品原理,以及具体的使用步骤。
101831 3
|
8天前
|
自然语言处理 Cloud Native Serverless
通义灵码牵手阿里云函数计算 FC ,打造智能编码新体验
近日,通义灵码正式进驻函数计算 FC WebIDE,让使用函数计算产品的开发者在其熟悉的云端集成开发环境中,无需再次登录即可使用通义灵码的智能编程能力,实现开发效率与代码质量的双重提升。
95408 2
|
5天前
|
物联网 PyTorch 测试技术
手把手教你捏一个自己的Agent
Modelscope AgentFabric是一个基于ModelScope-Agent的交互式智能体应用,用于方便地创建针对各种现实应用量身定制智能体,目前已经在生产级别落地。
|
1天前
|
NoSQL Java Redis
使用Redis实例搭建网上商城的商品相关性分析程序
本教程将指导您如何快速创建实例并搭建网上商城的商品相关性分析程序。(ApsaraDB for Redis)是兼容开源Redis协议标准的数据库服务,基于双机热备架构及集群架构,可满足高吞吐、低延迟及弹性变配等业务需求。
17081 0
Doodle Jump — 使用Flutter&Flame开发游戏真不错!
用Flutter&Flame开发游戏是一种什么体验?最近网上冲浪的时候,我偶然发现了一个国外的游戏网站,类似于国内的4399。在浏览时,我遇到了一款经典的小游戏:Doodle Jump...
112745 12
|
13天前
|
SQL 存储 JSON
Flink+Paimon+Hologres 构建实时湖仓数据分析
本文整理自阿里云高级专家喻良,在 Flink Forward Asia 2023 主会场的分享。
71377 1
Flink+Paimon+Hologres 构建实时湖仓数据分析
|
16天前
|
弹性计算 运维 安全
访问控制(RAM)|云上程序使用临时凭证的最佳实践
STS临时访问凭证是阿里云提供的一种临时访问权限管理服务,通过STS获取可以自定义时效和访问权限的临时身份凭证,减少长期访问密钥(AccessKey)泄露的风险。本文将为您介绍产品原理,以及具体的使用步骤。
151058 4

热门文章

最新文章