正则表达式用于匹配仅由字母列表构成的单词

Edu*_*tel 5 javascript regex regex-group regex-greedy regex-lookarounds

给定一组单词,我需要知道哪些单词仅由一组字母组成。即使此字母是验证集的一部分,该单词的字母也不能超过允许的数量。

例:

Char set: a, a, ã, c, e, l, m, m, m, o, o, o, o, t (fixed set)

Words set: mom, ace, to, toooo, ten, all, aaa (variable set)
Run Code Online (Sandbox Code Playgroud)

结果:

mom = true
ace = true
to = true
toooo = true
ten = false (n is not in the set)
all = false (there is only 1 L in the set)
aaa = false (theres is only 2 A in the set)
Run Code Online (Sandbox Code Playgroud)

如何在Javascript中生成此正则表达式?(区分大小写不是问题)。

我尝试了以下代码,但未成功:

var str = "ten"
var patt = new RegExp("^[a, a, ã, c, e, l, m, m, m, o, o, o, o, t]*");
console.log(patt.test(str));
Run Code Online (Sandbox Code Playgroud)

Pus*_*shi 5

尽管我认为此任务更适合通过编写一些代码而不使用正则表达式来完成。但是我可以想到的一种可行的方法是使用负面的前瞻。

让我们以您的字符集为例,您所允许的单词可以跟在后面的字母,并且不超过列表中显示的数量。

a, a, ã, c, e, l, m, m, m, o, o, o, o, t
Run Code Online (Sandbox Code Playgroud)

我们可以编写以下正则表达式,它使用负前瞻来丢弃包含的字符数超过每个字符的上述设置所允许的字符数的字符串,并最终使用1到N个字符的允许字符集捕获单词,其中N是总数字符。

^(?!([^a]*a){3})(?!([^ã]*ã){2})(?!([^c]*c){2})(?!([^e]*e){2})(?!([^l]*l){2})(?!([^m]*m){4})(?!([^o]*o){5})(?!([^t]*t){2})[aãcelmot]{1,14}$
Run Code Online (Sandbox Code Playgroud)

说明:

  • ^ -字符串开始
  • (?!([^a]*a){3})-如果a字符串中的数量为3或更大,则此负前瞻将拒绝输入,因为a集合中的总数仅为2。
  • (?!([^ã]*ã){2})-同样,如果ã字符串中的number等于2或更大(如设置的总数number ã仅为1),则该否定的超前查询将拒绝输入。
  • 以此类推,对于所有字符
  • [aãcelmot]{1,14}-此字符集捕获的允许字符至少为1到最大14,尽管我们也可以简单地写+为,因为已经使用否定前瞻检查了允许的最大字符数。
  • $ -字符串结尾

JS代码演示,

a, a, ã, c, e, l, m, m, m, o, o, o, o, t
Run Code Online (Sandbox Code Playgroud)