1、不以分号结尾
2、或者不以分号+空格(一个或多个空格,包括制表符) 结尾
如下面A符合要求,B不符合要求
A: y=5+3
B: x=7+5;
谢谢!
30 个解决方案
#1
Regex regExp = new Regex(@"(?s)(?<=\r\n|^).+(?![ ;])(?=\r\n|$)");
bool A_valid = regExp.IsMatch("y=5+3");
bool B_valid = regExp.IsMatch("x=7+5;");
bool A_valid = regExp.IsMatch("y=5+3");
bool B_valid = regExp.IsMatch("x=7+5;");
#2
Regex regExp = new Regex(@"(?s)(?<=\r\n|^).+(?![ ;])(?=\r\n|$)");
bool A_valid = regExp.IsMatch("y=5+3");
bool B_valid = regExp.IsMatch("x=7+5;");
#3
测试错了。。。没仔细看。忽略1楼回复。
private static void TestRegex23()
{
Regex regExp = new Regex(@"^(?!.+?;$).+$");
bool A_valid = regExp.IsMatch("y=5+3");
bool B_valid = regExp.IsMatch("x=7+5;");
Console.WriteLine(A_valid);
Console.WriteLine(B_valid);
}
#4
再改进一下,刚没考虑多个空格
private static void TestRegex23()
{
Regex regExp = new Regex(@"^(?!.+?(?:;| +)$).+$");
bool A_valid = regExp.IsMatch("y=5+3");
bool B_valid = regExp.IsMatch("x=7+5;");
Console.WriteLine(A_valid);
Console.WriteLine(B_valid);
}
#5
Thanks!
To wuyazhe:
下面的表达式应该为True,但是目前为False
bool A1_valid = regExp.IsMatch("y=5+3 "); //尾部包括空格
To wuyazhe:
下面的表达式应该为True,但是目前为False
bool A1_valid = regExp.IsMatch("y=5+3 "); //尾部包括空格
#6
以分号结束的,用下面的代码可以非常好匹配
Regex regExp = new Regex(@";\s*$");
但不以分号结束的,下面的代码却不工作
Regex regExp = new Regex(@"[^;]\s*$");
Regex regExp = new Regex(@";\s*$");
但不以分号结束的,下面的代码却不工作
Regex regExp = new Regex(@"[^;]\s*$");
#7
你如何测试的?我测试没错?
结果
False
False
False
private static void TestRegex23()
{
Regex regExp = new Regex(@"^(?!.+?(?:;| +)$).+$");
bool A_valid = regExp.IsMatch("y=5+3 ");
bool B_valid = regExp.IsMatch("x=7+5;");
bool A1_valid = regExp.IsMatch("y=5+3 "); //尾部包括空格
Console.WriteLine(A_valid);
Console.WriteLine(B_valid);
Console.WriteLine(A1_valid);
}
结果
False
False
False
#8
顶 !
#9
private static void TestRegex23()
{
Regex regExp = new Regex(@"^(?!.+?(?:;| +)$).+$");
bool A_valid = regExp.IsMatch("y=5+3 ");
bool B_valid = regExp.IsMatch("x=7+5;");
bool A1_valid = regExp.IsMatch("y=5+3 "); //尾部包括空格
Console.WriteLine(A_valid);
Console.WriteLine(B_valid);
Console.WriteLine(A1_valid);
}
要求的结果为
True
False
True
{
Regex regExp = new Regex(@"^(?!.+?(?:;| +)$).+$");
bool A_valid = regExp.IsMatch("y=5+3 ");
bool B_valid = regExp.IsMatch("x=7+5;");
bool A1_valid = regExp.IsMatch("y=5+3 "); //尾部包括空格
Console.WriteLine(A_valid);
Console.WriteLine(B_valid);
Console.WriteLine(A1_valid);
}
要求的结果为
True
False
True
#10
哦。没看仔细你的题目……
这样就是你要的
True
False
True
private static void TestRegex23()
{
Regex regExp = new Regex(@"^(?!.+?; *$).+$");
bool A_valid = regExp.IsMatch("y=5+3");
bool B_valid = regExp.IsMatch("x=7+5;");
bool A1_valid = regExp.IsMatch("y=5+3 "); //尾部包括空格
Console.WriteLine(A_valid);
Console.WriteLine(B_valid);
Console.WriteLine(A1_valid);
}
这样就是你要的
True
False
True
#11
Ok, Thanks! your code is OK!你能回答下面的问题吗
以分号结束的,用下面的代码可以非常好匹配
Regex regExp = new Regex(@";\s*$");
但不以分号结束的,下面的代码却不工作
Regex regExp = new Regex(@"[^;]\s*$");
以分号结束的,用下面的代码可以非常好匹配
Regex regExp = new Regex(@";\s*$");
但不以分号结束的,下面的代码却不工作
Regex regExp = new Regex(@"[^;]\s*$");
#12
但不以分号结束的,下面的代码却不工作
Regex regExp = new Regex(@"[^;] *$");
这样就可以了。
Regex regExp = new Regex(@"[^;] *$");
这样就可以了。
#13
Thanks!
奇怪!用\s 代替空格应该更好吗,为什么反而不工作
奇怪!用\s 代替空格应该更好吗,为什么反而不工作
#14
此外,用Regex regExp = new Regex(@"[^;] *$");是不是可以代替你的那个复杂的表达式Regex regExp = new Regex(@"^(?!.+?; *$).+$");
我看不太懂你的那个复杂的表达式:(
我看不太懂你的那个复杂的表达式:(
#15
\s包含;
这样
aaa;
这里[^;]匹配了最后一个a,然后的\s*匹配了;和后面的空格。
这样
aaa;
这里[^;]匹配了最后一个a,然后的\s*匹配了;和后面的空格。
#16
可以的。呵呵。其实你贴的只判断最后结果的效率比我写的高。
#17
奇怪! \s仅仅匹配空白字符,如制表、回车,为什么你说它能匹配分号;
#18
只是判断的话不用这么费劲
bool b = Regex.IsMatch(input, @"(?<!;\s*)$");
#19
ls方法好
#20
谢谢大家!我是一个初学者
@"(?<!;\s*)$") 请问第一个 ?号是什么意思 <是什么意思 !是什么意思
@"(?<!;\s*)$") 请问第一个 ?号是什么意思 <是什么意思 !是什么意思
#21
.*?[^;]\s*$
#22
(?<!)是前向断言,声明后面的字符,之前的内容,不能是!后面的部分。
(?<=Expression)
逆序肯定环视,表示所在位置左侧能够匹配Expression
(?<!Expression)
逆序否定环视,表示所在位置左侧不能匹配Expression
(?=Expression)
顺序肯定环视,表示所在位置右侧能够匹配Expression
(?!Expression)
顺序否定环视,表示所在位置右侧不能匹配Expression
客客师傅的博客
(?<=Expression)
逆序肯定环视,表示所在位置左侧能够匹配Expression
(?<!Expression)
逆序否定环视,表示所在位置左侧不能匹配Expression
(?=Expression)
顺序肯定环视,表示所在位置右侧能够匹配Expression
(?!Expression)
顺序否定环视,表示所在位置右侧不能匹配Expression
客客师傅的博客
#23
看不懂
#24
正则表达式通常包含字母文本(Literaltext)和元字符(metacharacter)
字母文本指的是普通文本如"abcde"可匹配字符串中任何包含"abcde"的字符串。
元字符则更加灵活运用通用的表达式匹配所有符合此表达式规律的字符串。
C#正则表达式语法一、匹配单个字符
[]——从中选择一个字符匹配
中间支持的类型:单词字符([ae])、非单词字符([!?,;@#$*])、字母范围([A-Z])、数字范围([0])
eg.正则表达式可匹配字符串
[ae]ffectaffect,effect
(此例中"[ae]"为元字符,"ffect"为字母文本)
注意:1.要在字符类中匹配连字符,那么把连字符号作为第一个字符列出即可。
2.可以在单个正则表达式中包含多个字符类。
eg.[01][0-9]:[0-5][0-9][ap]m可以用来匹配如12:59pm格式的所有时间
^——排除某些字符(在[]中表此意,还可表示字符串的开头)
eg.正则表达式可匹配字符串不可匹配字符串
m[^a]tmet,mit,m&t……mat
C#正则表达式语法二、匹配特殊字符
可以使用的特殊字符:
\t——匹配制表符
\r——匹配硬回车符
\f——匹配换页符
\n——匹配换行符
描述表示字符类的元字符:
.——匹配任何除了\n以外的字符(或者在单行模式中的任何字符)
\w——匹配任何单词字符(任何字母或数字)
\W——匹配任何非单词字符(除了字母和数字以外的任何字符)
\s——匹配任何空白字符(包括空格、换行、制表符等)
\S——匹配任何非空白字符(除了空格、换行、制表符等的任何字符)
\d——匹配任何数字字符(0~9的数字)
\D——匹配任何非数字字符(除了0~9以外的任何字符)
表示字符串中字符位置:
^——匹配字符串的开头(或者多行模式下行的开头)。
$——匹配字符串的结尾,或者是字符串结尾“\n”之前的最后一个字符,或者是多行模式中的行结尾。
\A——匹配字符串的开头(忽略多行模式)
\Z——匹配字符串的结尾或字符串结尾“\n”之前的最后一个字符(忽略多行模式)。
\z——匹配字符串的结尾。
\G——匹配当前搜索开始的位置。
\b——匹配单词的边界。
\B——匹配单词的非边界。
注意:
1.句点字符(.)特别有用。可以用它来表示任何一个字符。
eg.正则表达式可匹配字符串
01.17.8401/17/84,01-17-84,011784,01.17.84
2.可以使用\b匹配单词的边界
eg.正则表达式可匹配字符串不可匹配字符串
\blet\bletletter,hamlet
3.\A和\z在确保字符串所包含的是某个表达式,而不是其他内容时很用。
eg.要判断Text控件是否包含单词"sophia",而不含任何额外的字符、换行符或者空白。
\Asophia\z
4.句点字符(.)具有特殊的含义,若要表示字母字符本身的含义,在前面加一个反斜杠:\.
C#正则表达式语法三、匹配而选一的字符序列
|——匹配二选一
eg.正则表达式可匹配字符串
col(o|ou)rcolor,colour
注意:\b(bill|ted)和\bbill|ted是不同的。
后者还可以匹配"malted"因为\b元字符只应用于"bill"。
C#正则表达式语法四、用量词匹配
*——匹配0次或多次
+——匹配1次或多次
?——匹配0次或1次
{n}——恰好匹配n次
{n,}——至少匹配n次
{n,m}——至少匹配n次,但不多于m次
eg.正则表达式可匹配字符串
brothers?brother,brothers
eg.正则表达式可匹配字符串
\bp\d{3,5}\b以p开头,且后跟3~5个数字结尾
注意:也可以把量词与()一起使用,以便把该量词应用到整个字母序列。
eg.正则表达式可匹配字符串
(The)?schoolisbeautiful.schoolisbeautiful,Theschoolisbeautiful.
C#正则表达式语法五、识别正则表达式和贪婪
有些量词是贪婪的(greedy).他们会尽可能多的匹配字符。
如量词*匹配0个或多个字符。假设要匹配字符串中任何HTML标签。你可能会用如下正则表达式:
<.*>
现有字符串A<i>quantifier</i>canbe<big>greedy</big>
结果<.*>把<i>quantifier</i>canbe<big>greedy</big>都匹配上了。
要解决该问题,需要与量词一起使用一个特殊的非贪婪字符“?”,因此表达式变化如下:
<.*?>
这样就可以正确匹配<i>、</i>、<big>、</big>。
?能强制量词尽可能少地匹配字符,?还可以用在以下几个量词中:
*?——非贪婪的量词*
+?——非贪婪的量词+
??——非贪婪的量词?
{n}?——非贪婪的量词{n}
{n,}?——非贪婪的量词{n,}
{n,m}?——非贪婪的量词{n,m}
六、捕获和反向引用
捕获组(capturegroup)就像是正则表达式中的变量。捕获组可以捕获正则表达式中的字符模式,并且由正则表达式后面的编号或名称来引用改模式。
()——用来捕获其中的字符串
\数字——用编号来引用
eg.
正则表达式可匹配字符串
(\w)(\w)\2\1abba
注意:1.反向引用用来匹配html标签非常有效如<(\w+)></\1>可以匹配<table></table>等类似格式的标签。
2.默认情况下,只要使用圆括号,就会捕获圆括号内所包含的字符,可以使用n选项来禁用这个默认行为(在第7条里会详细介绍),或者添加?:到圆括号中。eg.(?:sophia)或(?n:sophia)此时不会捕获sophia。
(?<捕获组名称>)\k<捕获组名称>——用名称来引用
eg.
正则表达式可匹配字符串
(?<sophia>\w)abc\k<sophia>xabcx
注意:在替换模式中使用捕获组的格式略有不同,要用$1、$2等来按数值引用捕获,用${sophia}等名称来按名称引用捕获组
七、设置正则表达式的选项
eg.
stringstr="<h4>sophia</h4>"
RegExobjRegEx=newRegEx("<h(d)>(.*?)</h1>");
Response.Write(objRegEx.Replace(str,"<fontsize=$1>$2</font>"));
i——所执行的匹配是不区分大小写的(.net中的属性为IgnoreCase)
m——指定多行模式(.net中的属性为Multiline)
n——只捕获显示命名或编号的组(.net中的属性为ExplicitCapture)
c——编译正则表达式,这样会产生较快的执行速度,但启动会变慢(.net中的属性为Compiled)
s——指定单行模式(.net中的属性为SingleLine)
x——消除非转义空白字符和注释(.net中的属性为IgnorePatternWhitespace)
r——搜索从右到左进行(.net中的属性为RightToLeft)
-——表示禁用。
eg.(?im-r:sophia)允许不区分大小写匹配sophia,使用多行模式,但禁用了从右到左的匹配。
注意:1.m会影响如何解析起始元字符(^)和结束元字符($)。在默认情况^和$只匹配整个字符串的开头,即使字符串包含多行文本。如果启用了m,那么它们就可以匹配每行文本的开头和结尾。
2.s会影响如何解析句点元字符(.)。通常一个句点能匹配除了换行符以外的所有字符。但在单行模式下,句点也能匹配一个换行符。
以上是我对正则的一些收集,希望对你有帮助
字母文本指的是普通文本如"abcde"可匹配字符串中任何包含"abcde"的字符串。
元字符则更加灵活运用通用的表达式匹配所有符合此表达式规律的字符串。
C#正则表达式语法一、匹配单个字符
[]——从中选择一个字符匹配
中间支持的类型:单词字符([ae])、非单词字符([!?,;@#$*])、字母范围([A-Z])、数字范围([0])
eg.正则表达式可匹配字符串
[ae]ffectaffect,effect
(此例中"[ae]"为元字符,"ffect"为字母文本)
注意:1.要在字符类中匹配连字符,那么把连字符号作为第一个字符列出即可。
2.可以在单个正则表达式中包含多个字符类。
eg.[01][0-9]:[0-5][0-9][ap]m可以用来匹配如12:59pm格式的所有时间
^——排除某些字符(在[]中表此意,还可表示字符串的开头)
eg.正则表达式可匹配字符串不可匹配字符串
m[^a]tmet,mit,m&t……mat
C#正则表达式语法二、匹配特殊字符
可以使用的特殊字符:
\t——匹配制表符
\r——匹配硬回车符
\f——匹配换页符
\n——匹配换行符
描述表示字符类的元字符:
.——匹配任何除了\n以外的字符(或者在单行模式中的任何字符)
\w——匹配任何单词字符(任何字母或数字)
\W——匹配任何非单词字符(除了字母和数字以外的任何字符)
\s——匹配任何空白字符(包括空格、换行、制表符等)
\S——匹配任何非空白字符(除了空格、换行、制表符等的任何字符)
\d——匹配任何数字字符(0~9的数字)
\D——匹配任何非数字字符(除了0~9以外的任何字符)
表示字符串中字符位置:
^——匹配字符串的开头(或者多行模式下行的开头)。
$——匹配字符串的结尾,或者是字符串结尾“\n”之前的最后一个字符,或者是多行模式中的行结尾。
\A——匹配字符串的开头(忽略多行模式)
\Z——匹配字符串的结尾或字符串结尾“\n”之前的最后一个字符(忽略多行模式)。
\z——匹配字符串的结尾。
\G——匹配当前搜索开始的位置。
\b——匹配单词的边界。
\B——匹配单词的非边界。
注意:
1.句点字符(.)特别有用。可以用它来表示任何一个字符。
eg.正则表达式可匹配字符串
01.17.8401/17/84,01-17-84,011784,01.17.84
2.可以使用\b匹配单词的边界
eg.正则表达式可匹配字符串不可匹配字符串
\blet\bletletter,hamlet
3.\A和\z在确保字符串所包含的是某个表达式,而不是其他内容时很用。
eg.要判断Text控件是否包含单词"sophia",而不含任何额外的字符、换行符或者空白。
\Asophia\z
4.句点字符(.)具有特殊的含义,若要表示字母字符本身的含义,在前面加一个反斜杠:\.
C#正则表达式语法三、匹配而选一的字符序列
|——匹配二选一
eg.正则表达式可匹配字符串
col(o|ou)rcolor,colour
注意:\b(bill|ted)和\bbill|ted是不同的。
后者还可以匹配"malted"因为\b元字符只应用于"bill"。
C#正则表达式语法四、用量词匹配
*——匹配0次或多次
+——匹配1次或多次
?——匹配0次或1次
{n}——恰好匹配n次
{n,}——至少匹配n次
{n,m}——至少匹配n次,但不多于m次
eg.正则表达式可匹配字符串
brothers?brother,brothers
eg.正则表达式可匹配字符串
\bp\d{3,5}\b以p开头,且后跟3~5个数字结尾
注意:也可以把量词与()一起使用,以便把该量词应用到整个字母序列。
eg.正则表达式可匹配字符串
(The)?schoolisbeautiful.schoolisbeautiful,Theschoolisbeautiful.
C#正则表达式语法五、识别正则表达式和贪婪
有些量词是贪婪的(greedy).他们会尽可能多的匹配字符。
如量词*匹配0个或多个字符。假设要匹配字符串中任何HTML标签。你可能会用如下正则表达式:
<.*>
现有字符串A<i>quantifier</i>canbe<big>greedy</big>
结果<.*>把<i>quantifier</i>canbe<big>greedy</big>都匹配上了。
要解决该问题,需要与量词一起使用一个特殊的非贪婪字符“?”,因此表达式变化如下:
<.*?>
这样就可以正确匹配<i>、</i>、<big>、</big>。
?能强制量词尽可能少地匹配字符,?还可以用在以下几个量词中:
*?——非贪婪的量词*
+?——非贪婪的量词+
??——非贪婪的量词?
{n}?——非贪婪的量词{n}
{n,}?——非贪婪的量词{n,}
{n,m}?——非贪婪的量词{n,m}
六、捕获和反向引用
捕获组(capturegroup)就像是正则表达式中的变量。捕获组可以捕获正则表达式中的字符模式,并且由正则表达式后面的编号或名称来引用改模式。
()——用来捕获其中的字符串
\数字——用编号来引用
eg.
正则表达式可匹配字符串
(\w)(\w)\2\1abba
注意:1.反向引用用来匹配html标签非常有效如<(\w+)></\1>可以匹配<table></table>等类似格式的标签。
2.默认情况下,只要使用圆括号,就会捕获圆括号内所包含的字符,可以使用n选项来禁用这个默认行为(在第7条里会详细介绍),或者添加?:到圆括号中。eg.(?:sophia)或(?n:sophia)此时不会捕获sophia。
(?<捕获组名称>)\k<捕获组名称>——用名称来引用
eg.
正则表达式可匹配字符串
(?<sophia>\w)abc\k<sophia>xabcx
注意:在替换模式中使用捕获组的格式略有不同,要用$1、$2等来按数值引用捕获,用${sophia}等名称来按名称引用捕获组
七、设置正则表达式的选项
eg.
stringstr="<h4>sophia</h4>"
RegExobjRegEx=newRegEx("<h(d)>(.*?)</h1>");
Response.Write(objRegEx.Replace(str,"<fontsize=$1>$2</font>"));
i——所执行的匹配是不区分大小写的(.net中的属性为IgnoreCase)
m——指定多行模式(.net中的属性为Multiline)
n——只捕获显示命名或编号的组(.net中的属性为ExplicitCapture)
c——编译正则表达式,这样会产生较快的执行速度,但启动会变慢(.net中的属性为Compiled)
s——指定单行模式(.net中的属性为SingleLine)
x——消除非转义空白字符和注释(.net中的属性为IgnorePatternWhitespace)
r——搜索从右到左进行(.net中的属性为RightToLeft)
-——表示禁用。
eg.(?im-r:sophia)允许不区分大小写匹配sophia,使用多行模式,但禁用了从右到左的匹配。
注意:1.m会影响如何解析起始元字符(^)和结束元字符($)。在默认情况^和$只匹配整个字符串的开头,即使字符串包含多行文本。如果启用了m,那么它们就可以匹配每行文本的开头和结尾。
2.s会影响如何解析句点元字符(.)。通常一个句点能匹配除了换行符以外的所有字符。但在单行模式下,句点也能匹配一个换行符。
以上是我对正则的一些收集,希望对你有帮助
#25
谢谢!
Regex regExp = new Regex(@"[^;] *$"); 不能完全正常工作
它不能处理下面的内容(应该为False,实际结果为True)
bool B1_valid = regExp.IsMatch("x= 7+5; "); //等号后面有空格!
Regex regExp = new Regex(@"[^;] *$"); 不能完全正常工作
它不能处理下面的内容(应该为False,实际结果为True)
bool B1_valid = regExp.IsMatch("x= 7+5; "); //等号后面有空格!
#26
Regex regExp = new Regex("(?<!; *)$");
这个好使
这个好使
#27
谢谢!
我一直不明白为什么不能用 new Regex(@"(?<!;\s*)$");代替 new Regex("(?<!; *)$");
我一直不明白为什么不能用 new Regex(@"(?<!;\s*)$");代替 new Regex("(?<!; *)$");
#28
我已测试了Regex regExp = new Regex(@"^(?!.+?;\s*$).+$");和Regex regExp = new Regex(@"^(?!.+?; *$).+$");是没有什么区别的
#29
此外new Regex(@"^(?!.+?;\s*$).+$");中第一个问号表示子表达式不能匹配右侧的文本,请问第二个问号是什么意思,谢谢!
#30
因为\s表示空白字符,如空格、\t、\n、\r 等,如果测试的环境中存在换行的话,那就不会成功
当然红空格的话不能匹配换行,看你的实际使用了
第二个?是尽可能少的匹配的意思 +? = {1} ?? = *? = {0}
#1
Regex regExp = new Regex(@"(?s)(?<=\r\n|^).+(?![ ;])(?=\r\n|$)");
bool A_valid = regExp.IsMatch("y=5+3");
bool B_valid = regExp.IsMatch("x=7+5;");
bool A_valid = regExp.IsMatch("y=5+3");
bool B_valid = regExp.IsMatch("x=7+5;");
#2
Regex regExp = new Regex(@"(?s)(?<=\r\n|^).+(?![ ;])(?=\r\n|$)");
bool A_valid = regExp.IsMatch("y=5+3");
bool B_valid = regExp.IsMatch("x=7+5;");
#3
测试错了。。。没仔细看。忽略1楼回复。
private static void TestRegex23()
{
Regex regExp = new Regex(@"^(?!.+?;$).+$");
bool A_valid = regExp.IsMatch("y=5+3");
bool B_valid = regExp.IsMatch("x=7+5;");
Console.WriteLine(A_valid);
Console.WriteLine(B_valid);
}
#4
再改进一下,刚没考虑多个空格
private static void TestRegex23()
{
Regex regExp = new Regex(@"^(?!.+?(?:;| +)$).+$");
bool A_valid = regExp.IsMatch("y=5+3");
bool B_valid = regExp.IsMatch("x=7+5;");
Console.WriteLine(A_valid);
Console.WriteLine(B_valid);
}
#5
Thanks!
To wuyazhe:
下面的表达式应该为True,但是目前为False
bool A1_valid = regExp.IsMatch("y=5+3 "); //尾部包括空格
To wuyazhe:
下面的表达式应该为True,但是目前为False
bool A1_valid = regExp.IsMatch("y=5+3 "); //尾部包括空格
#6
以分号结束的,用下面的代码可以非常好匹配
Regex regExp = new Regex(@";\s*$");
但不以分号结束的,下面的代码却不工作
Regex regExp = new Regex(@"[^;]\s*$");
Regex regExp = new Regex(@";\s*$");
但不以分号结束的,下面的代码却不工作
Regex regExp = new Regex(@"[^;]\s*$");
#7
你如何测试的?我测试没错?
结果
False
False
False
private static void TestRegex23()
{
Regex regExp = new Regex(@"^(?!.+?(?:;| +)$).+$");
bool A_valid = regExp.IsMatch("y=5+3 ");
bool B_valid = regExp.IsMatch("x=7+5;");
bool A1_valid = regExp.IsMatch("y=5+3 "); //尾部包括空格
Console.WriteLine(A_valid);
Console.WriteLine(B_valid);
Console.WriteLine(A1_valid);
}
结果
False
False
False
#8
顶 !
#9
private static void TestRegex23()
{
Regex regExp = new Regex(@"^(?!.+?(?:;| +)$).+$");
bool A_valid = regExp.IsMatch("y=5+3 ");
bool B_valid = regExp.IsMatch("x=7+5;");
bool A1_valid = regExp.IsMatch("y=5+3 "); //尾部包括空格
Console.WriteLine(A_valid);
Console.WriteLine(B_valid);
Console.WriteLine(A1_valid);
}
要求的结果为
True
False
True
{
Regex regExp = new Regex(@"^(?!.+?(?:;| +)$).+$");
bool A_valid = regExp.IsMatch("y=5+3 ");
bool B_valid = regExp.IsMatch("x=7+5;");
bool A1_valid = regExp.IsMatch("y=5+3 "); //尾部包括空格
Console.WriteLine(A_valid);
Console.WriteLine(B_valid);
Console.WriteLine(A1_valid);
}
要求的结果为
True
False
True
#10
哦。没看仔细你的题目……
这样就是你要的
True
False
True
private static void TestRegex23()
{
Regex regExp = new Regex(@"^(?!.+?; *$).+$");
bool A_valid = regExp.IsMatch("y=5+3");
bool B_valid = regExp.IsMatch("x=7+5;");
bool A1_valid = regExp.IsMatch("y=5+3 "); //尾部包括空格
Console.WriteLine(A_valid);
Console.WriteLine(B_valid);
Console.WriteLine(A1_valid);
}
这样就是你要的
True
False
True
#11
Ok, Thanks! your code is OK!你能回答下面的问题吗
以分号结束的,用下面的代码可以非常好匹配
Regex regExp = new Regex(@";\s*$");
但不以分号结束的,下面的代码却不工作
Regex regExp = new Regex(@"[^;]\s*$");
以分号结束的,用下面的代码可以非常好匹配
Regex regExp = new Regex(@";\s*$");
但不以分号结束的,下面的代码却不工作
Regex regExp = new Regex(@"[^;]\s*$");
#12
但不以分号结束的,下面的代码却不工作
Regex regExp = new Regex(@"[^;] *$");
这样就可以了。
Regex regExp = new Regex(@"[^;] *$");
这样就可以了。
#13
Thanks!
奇怪!用\s 代替空格应该更好吗,为什么反而不工作
奇怪!用\s 代替空格应该更好吗,为什么反而不工作
#14
此外,用Regex regExp = new Regex(@"[^;] *$");是不是可以代替你的那个复杂的表达式Regex regExp = new Regex(@"^(?!.+?; *$).+$");
我看不太懂你的那个复杂的表达式:(
我看不太懂你的那个复杂的表达式:(
#15
\s包含;
这样
aaa;
这里[^;]匹配了最后一个a,然后的\s*匹配了;和后面的空格。
这样
aaa;
这里[^;]匹配了最后一个a,然后的\s*匹配了;和后面的空格。
#16
可以的。呵呵。其实你贴的只判断最后结果的效率比我写的高。
#17
奇怪! \s仅仅匹配空白字符,如制表、回车,为什么你说它能匹配分号;
#18
只是判断的话不用这么费劲
bool b = Regex.IsMatch(input, @"(?<!;\s*)$");
#19
ls方法好
#20
谢谢大家!我是一个初学者
@"(?<!;\s*)$") 请问第一个 ?号是什么意思 <是什么意思 !是什么意思
@"(?<!;\s*)$") 请问第一个 ?号是什么意思 <是什么意思 !是什么意思
#21
.*?[^;]\s*$
#22
(?<!)是前向断言,声明后面的字符,之前的内容,不能是!后面的部分。
(?<=Expression)
逆序肯定环视,表示所在位置左侧能够匹配Expression
(?<!Expression)
逆序否定环视,表示所在位置左侧不能匹配Expression
(?=Expression)
顺序肯定环视,表示所在位置右侧能够匹配Expression
(?!Expression)
顺序否定环视,表示所在位置右侧不能匹配Expression
客客师傅的博客
(?<=Expression)
逆序肯定环视,表示所在位置左侧能够匹配Expression
(?<!Expression)
逆序否定环视,表示所在位置左侧不能匹配Expression
(?=Expression)
顺序肯定环视,表示所在位置右侧能够匹配Expression
(?!Expression)
顺序否定环视,表示所在位置右侧不能匹配Expression
客客师傅的博客
#23
看不懂
#24
正则表达式通常包含字母文本(Literaltext)和元字符(metacharacter)
字母文本指的是普通文本如"abcde"可匹配字符串中任何包含"abcde"的字符串。
元字符则更加灵活运用通用的表达式匹配所有符合此表达式规律的字符串。
C#正则表达式语法一、匹配单个字符
[]——从中选择一个字符匹配
中间支持的类型:单词字符([ae])、非单词字符([!?,;@#$*])、字母范围([A-Z])、数字范围([0])
eg.正则表达式可匹配字符串
[ae]ffectaffect,effect
(此例中"[ae]"为元字符,"ffect"为字母文本)
注意:1.要在字符类中匹配连字符,那么把连字符号作为第一个字符列出即可。
2.可以在单个正则表达式中包含多个字符类。
eg.[01][0-9]:[0-5][0-9][ap]m可以用来匹配如12:59pm格式的所有时间
^——排除某些字符(在[]中表此意,还可表示字符串的开头)
eg.正则表达式可匹配字符串不可匹配字符串
m[^a]tmet,mit,m&t……mat
C#正则表达式语法二、匹配特殊字符
可以使用的特殊字符:
\t——匹配制表符
\r——匹配硬回车符
\f——匹配换页符
\n——匹配换行符
描述表示字符类的元字符:
.——匹配任何除了\n以外的字符(或者在单行模式中的任何字符)
\w——匹配任何单词字符(任何字母或数字)
\W——匹配任何非单词字符(除了字母和数字以外的任何字符)
\s——匹配任何空白字符(包括空格、换行、制表符等)
\S——匹配任何非空白字符(除了空格、换行、制表符等的任何字符)
\d——匹配任何数字字符(0~9的数字)
\D——匹配任何非数字字符(除了0~9以外的任何字符)
表示字符串中字符位置:
^——匹配字符串的开头(或者多行模式下行的开头)。
$——匹配字符串的结尾,或者是字符串结尾“\n”之前的最后一个字符,或者是多行模式中的行结尾。
\A——匹配字符串的开头(忽略多行模式)
\Z——匹配字符串的结尾或字符串结尾“\n”之前的最后一个字符(忽略多行模式)。
\z——匹配字符串的结尾。
\G——匹配当前搜索开始的位置。
\b——匹配单词的边界。
\B——匹配单词的非边界。
注意:
1.句点字符(.)特别有用。可以用它来表示任何一个字符。
eg.正则表达式可匹配字符串
01.17.8401/17/84,01-17-84,011784,01.17.84
2.可以使用\b匹配单词的边界
eg.正则表达式可匹配字符串不可匹配字符串
\blet\bletletter,hamlet
3.\A和\z在确保字符串所包含的是某个表达式,而不是其他内容时很用。
eg.要判断Text控件是否包含单词"sophia",而不含任何额外的字符、换行符或者空白。
\Asophia\z
4.句点字符(.)具有特殊的含义,若要表示字母字符本身的含义,在前面加一个反斜杠:\.
C#正则表达式语法三、匹配而选一的字符序列
|——匹配二选一
eg.正则表达式可匹配字符串
col(o|ou)rcolor,colour
注意:\b(bill|ted)和\bbill|ted是不同的。
后者还可以匹配"malted"因为\b元字符只应用于"bill"。
C#正则表达式语法四、用量词匹配
*——匹配0次或多次
+——匹配1次或多次
?——匹配0次或1次
{n}——恰好匹配n次
{n,}——至少匹配n次
{n,m}——至少匹配n次,但不多于m次
eg.正则表达式可匹配字符串
brothers?brother,brothers
eg.正则表达式可匹配字符串
\bp\d{3,5}\b以p开头,且后跟3~5个数字结尾
注意:也可以把量词与()一起使用,以便把该量词应用到整个字母序列。
eg.正则表达式可匹配字符串
(The)?schoolisbeautiful.schoolisbeautiful,Theschoolisbeautiful.
C#正则表达式语法五、识别正则表达式和贪婪
有些量词是贪婪的(greedy).他们会尽可能多的匹配字符。
如量词*匹配0个或多个字符。假设要匹配字符串中任何HTML标签。你可能会用如下正则表达式:
<.*>
现有字符串A<i>quantifier</i>canbe<big>greedy</big>
结果<.*>把<i>quantifier</i>canbe<big>greedy</big>都匹配上了。
要解决该问题,需要与量词一起使用一个特殊的非贪婪字符“?”,因此表达式变化如下:
<.*?>
这样就可以正确匹配<i>、</i>、<big>、</big>。
?能强制量词尽可能少地匹配字符,?还可以用在以下几个量词中:
*?——非贪婪的量词*
+?——非贪婪的量词+
??——非贪婪的量词?
{n}?——非贪婪的量词{n}
{n,}?——非贪婪的量词{n,}
{n,m}?——非贪婪的量词{n,m}
六、捕获和反向引用
捕获组(capturegroup)就像是正则表达式中的变量。捕获组可以捕获正则表达式中的字符模式,并且由正则表达式后面的编号或名称来引用改模式。
()——用来捕获其中的字符串
\数字——用编号来引用
eg.
正则表达式可匹配字符串
(\w)(\w)\2\1abba
注意:1.反向引用用来匹配html标签非常有效如<(\w+)></\1>可以匹配<table></table>等类似格式的标签。
2.默认情况下,只要使用圆括号,就会捕获圆括号内所包含的字符,可以使用n选项来禁用这个默认行为(在第7条里会详细介绍),或者添加?:到圆括号中。eg.(?:sophia)或(?n:sophia)此时不会捕获sophia。
(?<捕获组名称>)\k<捕获组名称>——用名称来引用
eg.
正则表达式可匹配字符串
(?<sophia>\w)abc\k<sophia>xabcx
注意:在替换模式中使用捕获组的格式略有不同,要用$1、$2等来按数值引用捕获,用${sophia}等名称来按名称引用捕获组
七、设置正则表达式的选项
eg.
stringstr="<h4>sophia</h4>"
RegExobjRegEx=newRegEx("<h(d)>(.*?)</h1>");
Response.Write(objRegEx.Replace(str,"<fontsize=$1>$2</font>"));
i——所执行的匹配是不区分大小写的(.net中的属性为IgnoreCase)
m——指定多行模式(.net中的属性为Multiline)
n——只捕获显示命名或编号的组(.net中的属性为ExplicitCapture)
c——编译正则表达式,这样会产生较快的执行速度,但启动会变慢(.net中的属性为Compiled)
s——指定单行模式(.net中的属性为SingleLine)
x——消除非转义空白字符和注释(.net中的属性为IgnorePatternWhitespace)
r——搜索从右到左进行(.net中的属性为RightToLeft)
-——表示禁用。
eg.(?im-r:sophia)允许不区分大小写匹配sophia,使用多行模式,但禁用了从右到左的匹配。
注意:1.m会影响如何解析起始元字符(^)和结束元字符($)。在默认情况^和$只匹配整个字符串的开头,即使字符串包含多行文本。如果启用了m,那么它们就可以匹配每行文本的开头和结尾。
2.s会影响如何解析句点元字符(.)。通常一个句点能匹配除了换行符以外的所有字符。但在单行模式下,句点也能匹配一个换行符。
以上是我对正则的一些收集,希望对你有帮助
字母文本指的是普通文本如"abcde"可匹配字符串中任何包含"abcde"的字符串。
元字符则更加灵活运用通用的表达式匹配所有符合此表达式规律的字符串。
C#正则表达式语法一、匹配单个字符
[]——从中选择一个字符匹配
中间支持的类型:单词字符([ae])、非单词字符([!?,;@#$*])、字母范围([A-Z])、数字范围([0])
eg.正则表达式可匹配字符串
[ae]ffectaffect,effect
(此例中"[ae]"为元字符,"ffect"为字母文本)
注意:1.要在字符类中匹配连字符,那么把连字符号作为第一个字符列出即可。
2.可以在单个正则表达式中包含多个字符类。
eg.[01][0-9]:[0-5][0-9][ap]m可以用来匹配如12:59pm格式的所有时间
^——排除某些字符(在[]中表此意,还可表示字符串的开头)
eg.正则表达式可匹配字符串不可匹配字符串
m[^a]tmet,mit,m&t……mat
C#正则表达式语法二、匹配特殊字符
可以使用的特殊字符:
\t——匹配制表符
\r——匹配硬回车符
\f——匹配换页符
\n——匹配换行符
描述表示字符类的元字符:
.——匹配任何除了\n以外的字符(或者在单行模式中的任何字符)
\w——匹配任何单词字符(任何字母或数字)
\W——匹配任何非单词字符(除了字母和数字以外的任何字符)
\s——匹配任何空白字符(包括空格、换行、制表符等)
\S——匹配任何非空白字符(除了空格、换行、制表符等的任何字符)
\d——匹配任何数字字符(0~9的数字)
\D——匹配任何非数字字符(除了0~9以外的任何字符)
表示字符串中字符位置:
^——匹配字符串的开头(或者多行模式下行的开头)。
$——匹配字符串的结尾,或者是字符串结尾“\n”之前的最后一个字符,或者是多行模式中的行结尾。
\A——匹配字符串的开头(忽略多行模式)
\Z——匹配字符串的结尾或字符串结尾“\n”之前的最后一个字符(忽略多行模式)。
\z——匹配字符串的结尾。
\G——匹配当前搜索开始的位置。
\b——匹配单词的边界。
\B——匹配单词的非边界。
注意:
1.句点字符(.)特别有用。可以用它来表示任何一个字符。
eg.正则表达式可匹配字符串
01.17.8401/17/84,01-17-84,011784,01.17.84
2.可以使用\b匹配单词的边界
eg.正则表达式可匹配字符串不可匹配字符串
\blet\bletletter,hamlet
3.\A和\z在确保字符串所包含的是某个表达式,而不是其他内容时很用。
eg.要判断Text控件是否包含单词"sophia",而不含任何额外的字符、换行符或者空白。
\Asophia\z
4.句点字符(.)具有特殊的含义,若要表示字母字符本身的含义,在前面加一个反斜杠:\.
C#正则表达式语法三、匹配而选一的字符序列
|——匹配二选一
eg.正则表达式可匹配字符串
col(o|ou)rcolor,colour
注意:\b(bill|ted)和\bbill|ted是不同的。
后者还可以匹配"malted"因为\b元字符只应用于"bill"。
C#正则表达式语法四、用量词匹配
*——匹配0次或多次
+——匹配1次或多次
?——匹配0次或1次
{n}——恰好匹配n次
{n,}——至少匹配n次
{n,m}——至少匹配n次,但不多于m次
eg.正则表达式可匹配字符串
brothers?brother,brothers
eg.正则表达式可匹配字符串
\bp\d{3,5}\b以p开头,且后跟3~5个数字结尾
注意:也可以把量词与()一起使用,以便把该量词应用到整个字母序列。
eg.正则表达式可匹配字符串
(The)?schoolisbeautiful.schoolisbeautiful,Theschoolisbeautiful.
C#正则表达式语法五、识别正则表达式和贪婪
有些量词是贪婪的(greedy).他们会尽可能多的匹配字符。
如量词*匹配0个或多个字符。假设要匹配字符串中任何HTML标签。你可能会用如下正则表达式:
<.*>
现有字符串A<i>quantifier</i>canbe<big>greedy</big>
结果<.*>把<i>quantifier</i>canbe<big>greedy</big>都匹配上了。
要解决该问题,需要与量词一起使用一个特殊的非贪婪字符“?”,因此表达式变化如下:
<.*?>
这样就可以正确匹配<i>、</i>、<big>、</big>。
?能强制量词尽可能少地匹配字符,?还可以用在以下几个量词中:
*?——非贪婪的量词*
+?——非贪婪的量词+
??——非贪婪的量词?
{n}?——非贪婪的量词{n}
{n,}?——非贪婪的量词{n,}
{n,m}?——非贪婪的量词{n,m}
六、捕获和反向引用
捕获组(capturegroup)就像是正则表达式中的变量。捕获组可以捕获正则表达式中的字符模式,并且由正则表达式后面的编号或名称来引用改模式。
()——用来捕获其中的字符串
\数字——用编号来引用
eg.
正则表达式可匹配字符串
(\w)(\w)\2\1abba
注意:1.反向引用用来匹配html标签非常有效如<(\w+)></\1>可以匹配<table></table>等类似格式的标签。
2.默认情况下,只要使用圆括号,就会捕获圆括号内所包含的字符,可以使用n选项来禁用这个默认行为(在第7条里会详细介绍),或者添加?:到圆括号中。eg.(?:sophia)或(?n:sophia)此时不会捕获sophia。
(?<捕获组名称>)\k<捕获组名称>——用名称来引用
eg.
正则表达式可匹配字符串
(?<sophia>\w)abc\k<sophia>xabcx
注意:在替换模式中使用捕获组的格式略有不同,要用$1、$2等来按数值引用捕获,用${sophia}等名称来按名称引用捕获组
七、设置正则表达式的选项
eg.
stringstr="<h4>sophia</h4>"
RegExobjRegEx=newRegEx("<h(d)>(.*?)</h1>");
Response.Write(objRegEx.Replace(str,"<fontsize=$1>$2</font>"));
i——所执行的匹配是不区分大小写的(.net中的属性为IgnoreCase)
m——指定多行模式(.net中的属性为Multiline)
n——只捕获显示命名或编号的组(.net中的属性为ExplicitCapture)
c——编译正则表达式,这样会产生较快的执行速度,但启动会变慢(.net中的属性为Compiled)
s——指定单行模式(.net中的属性为SingleLine)
x——消除非转义空白字符和注释(.net中的属性为IgnorePatternWhitespace)
r——搜索从右到左进行(.net中的属性为RightToLeft)
-——表示禁用。
eg.(?im-r:sophia)允许不区分大小写匹配sophia,使用多行模式,但禁用了从右到左的匹配。
注意:1.m会影响如何解析起始元字符(^)和结束元字符($)。在默认情况^和$只匹配整个字符串的开头,即使字符串包含多行文本。如果启用了m,那么它们就可以匹配每行文本的开头和结尾。
2.s会影响如何解析句点元字符(.)。通常一个句点能匹配除了换行符以外的所有字符。但在单行模式下,句点也能匹配一个换行符。
以上是我对正则的一些收集,希望对你有帮助
#25
谢谢!
Regex regExp = new Regex(@"[^;] *$"); 不能完全正常工作
它不能处理下面的内容(应该为False,实际结果为True)
bool B1_valid = regExp.IsMatch("x= 7+5; "); //等号后面有空格!
Regex regExp = new Regex(@"[^;] *$"); 不能完全正常工作
它不能处理下面的内容(应该为False,实际结果为True)
bool B1_valid = regExp.IsMatch("x= 7+5; "); //等号后面有空格!
#26
Regex regExp = new Regex("(?<!; *)$");
这个好使
这个好使
#27
谢谢!
我一直不明白为什么不能用 new Regex(@"(?<!;\s*)$");代替 new Regex("(?<!; *)$");
我一直不明白为什么不能用 new Regex(@"(?<!;\s*)$");代替 new Regex("(?<!; *)$");
#28
我已测试了Regex regExp = new Regex(@"^(?!.+?;\s*$).+$");和Regex regExp = new Regex(@"^(?!.+?; *$).+$");是没有什么区别的
#29
此外new Regex(@"^(?!.+?;\s*$).+$");中第一个问号表示子表达式不能匹配右侧的文本,请问第二个问号是什么意思,谢谢!
#30
因为\s表示空白字符,如空格、\t、\n、\r 等,如果测试的环境中存在换行的话,那就不会成功
当然红空格的话不能匹配换行,看你的实际使用了
第二个?是尽可能少的匹配的意思 +? = {1} ?? = *? = {0}