C#正则表达式。

什么是正则表达式:

正则表达式是用来进行文本处理的技术,是语言无关的。

是由普通字符和特殊字符组成的文字模式,用来描述字符串的特征。

元字符:

1、  .    :  除 \n 以外的任意的单个字符。   加\ 可以转义

a.b----- 表示 a  b  之间可以有除了  \n   的任意字符。

2、 [ ]   :取其中一个字符(必须)。  [  a -z ]    [  a-zA-z  ] ,点出现在里面表示一个普通点。

3、|   : 或   z|food      z或food    (z)|(f)ood     z 或f     ood

4、()  表示优先级    或  表示提取组

5、*   :  a.*b       * 表示前面的表达式出现0次或多次。

6、+ : a.+b     + 表示前面的表达式出现一次或多次

7、? : a.?b     ?表示前面的表达式出现0次或1次。

8、{}  : [0-9] {8}    固定次数    [0-9] {4,7}  最少  最多

9、^   :  ^ a     必须以a开头。

10、 $   :   $a  以a结尾。

11、[  ^a ]  :   不能有a的一个字符

12、 \d  : 0-9      加@

13、|D   :除0-9

14、\w : 所有英文数字单字符。汉字也行  下划线

15、\W  :  除了。。。。

16、\s  : 表示所有不可见字符。  \S  :   除了。。。。。

使用正则表达式。

    class Program
{
static void Main(string[] args)
{
//Regex.IsMatch(); //判断给定的字符串是否匹配某个正则表达式。
//Regex.Match(); //用来从给定的字符串中按照正则表达式的要求提取【一个】匹配的字符串。
//Regex.Matches(); //用来从给定的字符串中按照正则表达式的要求提取【所有】匹配的字符串。
// Regex.Replace(); //替换所有正则表达式匹配的字符串为另外一个字符串。
while (true)
{
Console.WriteLine("输入一个字符串");
string str = Console.ReadLine();
//验证给定的字符串是否为合法的邮政编码。
//要想完全匹配,必须加 ^ 和 $ . 否则只要含有就返回True
bool b = Regex.IsMatch(str, "^[0-9]{6}$");
Console.WriteLine(b);
}
}
}
}

字符串提取:

 class Program
{
static void Main(string[] args)
{
//Regex.IsMatch(); //判断给定的字符串是否匹配某个正则表达式。
//Regex.Match(); //用来从给定的字符串中按照正则表达式的要求提取【一个】匹配的字符串。
//Regex.Matches(); //用来从给定的字符串中按照正则表达式的要求提取【所有】匹配的字符串。
// Regex.Replace(); //替换所有正则表达式匹配的字符串为另外一个字符串。 //提取字符串中所有匹配项。
string str = "ss 23 哈哈 2233收索 66aa12";
MatchCollection matches= Regex.Matches(str, "[0-9]+");
foreach (var item in matches)
{
Console.WriteLine(item);
} }
}

贪婪模式与非贪婪模式。

贪婪:.+    :  默认为贪婪模式,尽可能多的匹配。

非贪婪: .+?  : 尽可能少的匹配(1个)  在限定符后使用  ?  表示终止贪婪模式。

class Program
{
static void Main(string[] args)
{
//Regex.IsMatch(); //判断给定的字符串是否匹配某个正则表达式。
//Regex.Match(); //用来从给定的字符串中按照正则表达式的要求提取【一个】匹配的字符串。
//Regex.Matches(); //用来从给定的字符串中按照正则表达式的要求提取【所有】匹配的字符串。
// Regex.Replace(); //替换所有正则表达式匹配的字符串为另外一个字符串。
string msg = "大家好,我是杨幂。我是张靓颖。我是刘德华。";
MatchCollection matches = Regex.Matches(msg, "我是.*?。");
foreach (var item in matches)
{
Console.WriteLine(item);
} }
}

提取网页上的邮箱。

class Program
{
static void Main(string[] args)
{
//1、下载字符串。
WebClient client = new WebClient();
string html = client.DownloadString("file:///C:/Users/天/Desktop/1.html");
//从字符串中提取邮件地址。
MatchCollection matches = Regex.Matches(html, @"[a-zA-Z0-9]+@[a-zA-Z0-9.]+");
foreach (Match item in matches)
{
Console.WriteLine(item.Value);
}
Console.WriteLine("一共{0}个邮箱地址",matches.Count);
}
}

正则替换:

Regex.Replace()

class Program
{
static void Main(string[] args)
{
string msg = "你aaa好aa啊aaaaa";
msg = Regex.Replace(msg, "a+", "A");
Console.WriteLine(msg);
}
}

替换组实现:

 class Program
{
static void Main(string[] args)
{
//把 ' ' 里的内容替换为 【 】
string msg = "hello 'welcom' to 'china'";
msg = Regex.Replace(msg, "'(.+?)'", "【$1】");
Console.WriteLine(msg);
}
}

隐藏手机号:

class Program
{
static void Main(string[] args)
{
string msg = "张玉昊 15983531955 胡云钰 15008306525";
msg = Regex.Replace(msg, "([0-9]{3})[0-9]{4}([0-9]{4})", "$1****$2");
Console.WriteLine(msg);
}
}

\b  的使用   判断是否为一个单词   \bdog\b  --- 是不是dog这个单词。

提取出所有三个字母的单词:

static void Main(string[] args)
{ string str = "this is a dog, it's not a cat.";
MatchCollection matches= Regex.Matches(str, @"\b[a-zA-Z]{3}\b");
foreach (Match item in matches)
{
Console.WriteLine(item.Value);
}
}

反向引用。

反向引用使用  \    替换引用用  $

输出  我喜欢你

class Program
{
static void Main(string[] args)
{ string str = "我我我喜喜欢你你";
str = Regex.Replace(str, @"(.)\1+","$1");
Console.WriteLine(str);
}
}
上一篇:Visual Studio问题集锦:coloader80.dll未正确安装


下一篇:Eclipse for Java EE软件操作集锦(二)