正则表达式重复模式用逗号分隔

use*_*614 6 regex

我有以下正则表达式:

.regex(/^(?!^[0-9]*$)(?!^[a-zA-Z]*$)^([a-zA-Z0-9]{4})$/)
Run Code Online (Sandbox Code Playgroud)

必须正好是4个字符必须包含至少1个数字和1个alpha

虽然我很少做正则表达,但这相对容易.我现在有一个新的要求,我试图实现,但不能正确.

新要求:能够使用与以前相同类型的输入的逗号分隔列表.不能以逗号结尾.每个项目必须符合上述规则(4个字符,至少在数字上,至少一个alpha)

Valid:  123F,U6Y7,OOO8
Invalid:  Q2R4,
Invalid:  Q2R4,1234
Invalid:  Q2R4,ABCD
Invalid:  Q2R4,N6
Run Code Online (Sandbox Code Playgroud)

非常感谢你的帮助!谢谢!

rob*_*off 6

其他一些答案正在重复前瞻断言.这不是必要的.

这是一个匹配逗号分隔的原子序列的正则表达式,其中每个原子是四个字母数字字符:

^[A-Z0-9]{4}(?:,[A-Z0-9]{4})*$
Run Code Online (Sandbox Code Playgroud)

当然,这不是你想要的.你不希望所有原子都是字母的.这是一个负面的先行断言,可以防止在文本中的任何位置匹配这样的原子:

(?!.*[A-Z]{4})
Run Code Online (Sandbox Code Playgroud)

而且你不希望所有原子都是数字:

(?!.*[0-9]{4})
Run Code Online (Sandbox Code Playgroud)

把它们放在一起:

^(?!.*[A-Z]{4})(?!.*[0-9]{4})[A-Z0-9]{4}(?:,[A-Z0-9]{4})*$
Run Code Online (Sandbox Code Playgroud)


Cai*_*ira 2

尝试使用这个正则表达式(正则表达式测试):

.regex(/^(?:(?![0-9]{4}|[a-zA-Z]{4})[a-zA-Z0-9]{4})(?:(?:\b\,)(?![0-9]{4}|[a-zA-Z]{4})[a-zA-Z0-9]{4})*$/)
Run Code Online (Sandbox Code Playgroud)

解释:

  • (?:\b\,)->,当前面有单词边界时才与字符串开头的a 匹配

  • (?:(?![0-9]{4}|[a-zA-Z]{4})[a-zA-Z0-9]{4})->仅没有4 个数字或 4 个字母时,才将字符串与字母和数字匹配

  • @ZachLeighton:如果不能使正则表达式更易于阅读,则无需缩短正则表达式。 (2认同)