十五、C# 使用查询表达式的LINQ
string[] KeyWords = { "", "c*d", "xxm","2*","ab" };
IEnumerable<string> selection = from word in KeyWords
where !word.Contains('*')
select word;
foreach (string word in selection)
{
Console.WriteLine(word);
}
IEnumerable<FileInfo> files = from fileName in Directory.GetFiles("D:\\")
select new FileInfo(fileName);
foreach (FileInfo file in files)
{
Console.WriteLine("{0}({1})", file.Name, file.LastWriteTime);
}
var files = from fileName in Directory.GetFiles("D:\\")
select new
{
Name = fileName,
LastWriteTime = new FileInfo(fileName).LastAccessTime
};
foreach (var file in files)
{
Console.WriteLine("{0}({1})", file.Name, file.LastWriteTime);
}
var files = from fileName in Directory.GetFiles("D:\\")
where File.GetLastWriteTime(fileName).Year<
select new
{
Name = fileName,
LastWriteTime = new FileInfo(fileName).LastAccessTime
};
foreach (var file in files)
{
Console.WriteLine("{0}({1})", file.Name, file.LastWriteTime);
}
var files = from fileName in Directory.GetFiles("D:\\")
where File.GetLastWriteTime(fileName).Year<
orderby (new FileInfo(fileName)).Length descending,fileName
select new
{
Name = fileName,
LastWriteTime = new FileInfo(fileName).LastAccessTime
};
foreach (var file in files)
{
Console.WriteLine("{0}({1})", file.Name, file.LastWriteTime);
}
var files = from fileName in Directory.GetFiles("D:\\")
where File.GetLastWriteTime(fileName).Year <
let file = new FileInfo(fileName)
orderby file.Length descending, fileName
select new
{
Name = fileName,
LastWriteTime = file.LastAccessTime
};
string[] KeyWords = { "", "c*d", "xxm", "2*", "ab" };
IEnumerable<IGrouping<bool, string>> selection =
from word in KeyWords
group word by word.Contains('*');
//分成了两组,每一组都是一个 IGrouping<bool, string> 类型
foreach (IGrouping<bool, string> wordGroup in selection)
{
Console.WriteLine(Environment.NewLine + "{0}", wordGroup.Key ? "关键字" : "非关键字");
foreach (string word in wordGroup)
{
Console.WriteLine(word);
}
}
string[] KeyWords = { "", "c*d", "xxm", "2*", "ab" };
IEnumerable<IGrouping<bool, string>> keywordGroups =
from word in KeyWords
group word by word.Contains('*');
var selection = from groups in keywordGroups
select new
{
IsContextualKeyword = groups.Key,
Items = groups
};
//分成了两组,每一组都是一个
//{
// IsContextualKeyword = groups.Key,
// Items = groups
//};类型
foreach (var wordGroup in selection)
{
Console.WriteLine(Environment.NewLine + "{0}", wordGroup.IsContextualKeyword ? "关键字" : "非关键字");
foreach (string word in wordGroup.Items)
{
Console.WriteLine(word);
}
}
string[] KeyWords = { "", "c*d", "xxm", "2*", "ab" };
var selection =
from word in KeyWords
group word by word.Contains('*')
into groups//范围变量,代表group by子句返回的每个数据项
select new
{
IsContextualKeyword = groups.Key,
Items = groups
};
//分成了两组,每一组都是一个
//{
// IsContextualKeyword = groups.Key,
// Items = groups
//};类型
foreach (var wordGroup in selection)
{
Console.WriteLine(Environment.NewLine + "{0}", wordGroup.IsContextualKeyword ? "关键字" : "非关键字");
foreach (string word in wordGroup.Items)
{
Console.WriteLine(word);
}
}
var selection = (
from word in KeyWords
select word
).Distinct();
十五、C# 使用查询表达式的LINQ的更多相关文章
- C#复习笔记(4)--C#3:革新写代码的方式(查询表达式和LINQ to object(下))
查询表达式和LINQ to object(下) 接下来我们要研究的大部分都会涉及到透明标识符 let子句和透明标识符 let子句不过是引入了一个新的范围变量.他的值是基于其他范围变量的.let 标识符 ...
- 《C#本质论》读书笔记(15)使用查询表达式的LINQ
15.1 查询表达式的概念 简单的查询表达式 private static void ShowContextualKeywords1() { IEnumerable<string> sel ...
- C#学习笔记五: C#3.0Lambda表达式及Linq解析
最早使用到Lambda表达式是因为一个需求:如果一个数组是:int[] s = new int[]{1,3,5,9,14,16,22};例如只想要这个数组中小于15的元素然后重新组装成一个数组或者直接 ...
- 查询表达式和LINQ to Objects
查询表达式实际上是由编译器“预处理”为“普通”的C#代码,接着以完全普通的方式进行编译.这种巧妙的发式将查询集合到了语言中,而无须把语义改得乱七八糟 LINQ的介绍 LINQ中的基础概念 降低两种数据 ...
- NHibernate系列文章二十五:NHibernate查询之Query Over查询(附程序下载)
摘要 这一篇文章介绍在NHibernate 3.2里引入的Query Over查询,Query Over查询跟Criteria查询类似.首先创建IQueryOver对象,然后通过调用该对象的API函数 ...
- 第十五节:Expression表达式目录树(与委托的区别、自行拼接、总结几类实例间的拷贝)
一. 基本介绍 回忆: 最早接触到表达式目录树(Expression)可能要追溯到几年前使用EF早期的时候,发现where方法里的参数是Expression<Func<T,bool> ...
- PowerBI开发 第十五篇:DAX 表达式(时间+过滤+关系)
DAX表达式中包含时间关系(Time Intelligence)相关的函数,用于对日期维度进行累加.同比和环比等分析.PowerBI能够创建关系,通过过滤器来对影响计算的上下文. 一,时间关系 DAX ...
- 2.1 LINQ的查询表达式
在进行LINQ查询的编写之前,首先需要了解查询表达式.查询表达式是LINQ查询的基础,也是最常用的编写LINQ查询的方法. 查询表达式由查询关键字和对应的操作数组成的表达式整体.其中,查询关键字是常用 ...
- Ext JS学习第十六天 事件机制event(一) DotNet进阶系列(持续更新) 第一节:.Net版基于WebSocket的聊天室样例 第十五节:深入理解async和await的作用及各种适用场景和用法 第十五节:深入理解async和await的作用及各种适用场景和用法 前端自动化准备和详细配置(NVM、NPM/CNPM、NodeJs、NRM、WebPack、Gulp/Grunt、G
code&monkey Ext JS学习第十六天 事件机制event(一) 此文用来记录学习笔记: 休息了好几天,从今天开始继续保持更新,鞭策自己学习 今天我们来说一说什么是事件,对于事件 ...
随机推荐
- java学习面向对象之内部类
什么是面向对象内部类呢?所谓的内部类,即从字面意义上来理解的话,就是把类放到类当中. 那么内部类都有什么特点呢? 1.内部类可以访问包裹他的类的成员. 2.如果包裹他的类想访问被其包裹的类的话就得实例 ...
- HDU 5920 Ugly Problem 【模拟】 (2016中国大学生程序设计竞赛(长春))
Ugly Problem Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Tota ...
- 495. Kids and Prizes
http://acm.sgu.ru/problem.php?contest=0&problem=495 学习:当一条路走不通,换一种对象考虑,还有考虑对立面. 495. Kids and Pr ...
- iOS 多线程学习笔记 —— GCD
本文复制.参考自文章:iOS多线程编程之Grand Central Dispatch(GCD)介绍和使用 ,主要为了加强个人对知识的理解和记忆,不做他用.原作者声明: 著作权声明:本文由http:// ...
- Java基础(三)
这里有我之前上课总结的一些知识点以及代码大部分是老师讲的笔记 个人认为是非常好的,,也是比较经典的内容,真诚的希望这些对于那些想学习的人有所帮助! 由于代码是分模块的上传非常的不便.也比较多,讲的也是 ...
- poj 3678 Katu Puzzle(Two Sat)
题目链接:http://poj.org/problem?id=3678 代码: #include<cstdio> #include<cstring> #include<i ...
- 自动化运维工具Ansible详细部署 - 人生理想在于坚持不懈 - 51CTO技术博客
自动化运维工具Ansible详细部署 - 人生理想在于坚持不懈 - 51CTO技术博客 自动化运维工具Ansible详细部署
- Broken line - SGU 124(判断点与多边形的关系)
题目大意:RT 分析:构造一条射线,如果穿越偶数条边,那么就在多边形外面,如果穿越奇数条边,那么就在多边形里面. 代码如下: ===================================== ...
- N2N 对等VPN网络
n2n是一个二层的虚拟专网,允许用户开发网络中典型的P2P应用而不是在应用层开发.这就意味着用户可以透明的得到本地地址,只要新的IP地址在一个子网内,无论两台机器处于什么位置都能够ping通对方. N ...
- SharePoint 2013的100个新功能之网站管理(二)
一:SharePoint 2013的网站策略 网站策略指的是自动关闭或删除网站的条件.有四个选项:不自动关闭或删除网站.自动删除网站.自动关闭并删除网站和运行一个工作流来关闭.删除网站. 二:新的主题 ...