初见C#之欣喜 -- 有关正则和LINQ

这两天由于作业的原因用C#写了个小程序,苦恼于陌生的函数、规则,苦恼于想写的模式在C#中找不到相应的实现方法。不过在苦恼之外却有两个很让我欣喜的东西,正则表达式和LINQ

学过编译原理的同学都很熟悉正则表达式,基于正则式的词法语法自动分析程序(LEXYACC)的强大更是让我记忆犹新。

 

下面介绍下正则表达式吧。

正则表达式的表达能力等价于正则文法,正则表达式的定义如下:
1. 字母表中的任意字母是正则表达式,空串和空集也是正则表达式;
2. 
如果r, s是正则表达式,那么r|s, rs, r*, (r)也是正则表达式。

正则表达式可以表示很多模式,如:

\d{2}-\d{5}  一个2位数字,一个连字符以及一个5位数字组成ID

^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$  正浮点数

 

因此正则式在字符串处理方面有其得天独厚的优势,但是传统的标准C/C++并没有提供这方面的支持,反倒是一些第三方库加入了相应功能。到了C#,正则式被很好的支持和运用了,无论是字符串的匹配、替换,还是分词函数中都能看见它的身影,这无疑为我们处理字符串提供了很大的便捷。

如以下模式就能用于匹配以数字结束并含有小写字母的单词,比我们手写的匹配程序要简单方便许多。

Regex rEndingwithNumbers = new Regex(@"[a-z][0-9]+$", RegexOptions.Compiled);

 

LINQ则是我们可以用一种类似数据库查询语句的方式来处理数据。

From, in, where, select, join, on, orderby, group等查询运算符的引入大大简化了一些数据处理程序的编写复杂性。

例如在一个词库中,用一个LINQ查询就可以实现词长筛选,词频统计,按要求排序等一系列功能。

 

以上皆是本人作为一个菜鸟接触C#几天的感受,理解的比较肤浅,欢迎拍砖。

posted @ 2010-11-28 19:50  ustc_msra_ase  阅读(708)  评论(0编辑  收藏  举报