我想要一个正则表达式,防止符号,只允许字母和数字。下面的正则表达式工作得很好,但它不允许单词之间有空格。

^[a-zA-Z0-9_]*$

例如,当使用这个正则表达式时,“HelloWorld”是可以的,但“HelloWorld”不匹配。

我如何调整它允许空格?


当前回答

试一试:

^(\w+ ?)*$

解释:

\w             - alias for [a-zA-Z_0-9]
"whitespace"?  - allow whitespace after word, set is as optional

其他回答

博士tl;

只需要在你的角色类别中添加一个空格。

^[a-zA-Z0-9_ ]*$

 


现在,如果你想严格一点…

以上说法并不完全正确。由于*意味着0或更多,它将匹配以下所有通常不打算匹配的情况:

空字符串""。 完全由空格“”组成的字符串。 以空格开头和/或结尾的字符串," Hello World "。 单词之间包含多个空格的字符串,“Hello World”。

起初我认为这些细节不值得讨论,因为OP问的是一个如此基本的问题,以至于严格似乎不是一个问题。现在这个问题已经很流行了,我想说……

...请使用@stema的答案。

在我看来(不用\w),它的意思是:

^[a-zA-Z0-9_]+( [a-zA-Z0-9_]+)*$

(无论如何,请给@stema投票。)

关于这个(和@stema的)答案,有几点需要注意:

如果你想允许单词之间有多个空格(比如,如果你想允许意外的双空格,或者如果你从PDF中复制粘贴文本),那么在空格后添加一个+: ^ \ w + (+ \ w +) *美元 如果你想允许制表符和换行符(空白字符),那么用\s+替换空格: ^ \ w + (\ s + \ w +) *美元 这里我建议在默认情况下使用+,因为,例如,Windows换行符由两个空格字符组成,分别是\r\n,所以您需要使用+来捕获这两个字符。

还是不行?

检查您使用的正则表达式的方言。*在Java等语言中,你必须转义反斜杠,即\\w和\\s。在更老的或更基本的语言和实用程序中,如sed, \w和\s是没有定义的,所以用字符类分别写出来,例如[a-zA-Z0-9_]和[\f\n\p\r\t]。

 


*我知道这个问题的标签是vb.net,但根据25000 +的阅读量,我猜不仅仅是那些人遇到了这个问题。目前,它是谷歌上搜索短语正则表达式空间词的第一个热点。

只适用于字母:

^([a-zA-Z])+(\s)+[a-zA-Z]+$

对于字母数字值和_:

^(\w)+(\s)+\w+$

只需在正则表达式模式的末尾添加一个空格,如下所示:

[a-zA-Z0-9_ ]

这个正则表达式

^\w+(\s\w+)*$

将只允许单词之间有一个空格,不允许开头或结尾空格。

正则表达式解释如下:

^ Assert position at start of the string \w+ Match any word character [a-zA-Z0-9_] Quantifier: + Between one and unlimited times, as many times as possible, giving back as needed [greedy] 1st Capturing group (\s\w+)* Quantifier: * Between zero and unlimited times, as many times as possible, giving back as needed [greedy] \s Match any white space character [\r\n\t\f ] \w+ Match any word character [a-zA-Z0-9_] Quantifier: + Between one and unlimited times, as many times as possible, giving back as needed [greedy] $ Assert position at end of the string

试一试:

^(\w+ ?)*$

解释:

\w             - alias for [a-zA-Z_0-9]
"whitespace"?  - allow whitespace after word, set is as optional