l.alpha*2
是l.alpha
*
l.P(2)
。
所以不,那匹配[a-z]..
。
查看输出lpeg.print(timezone)
以确认。(注意我ll
对语言环境数据的使用。把它放在同一个表中会失去原来的print
调试功能。)
> l=require"lpeg"
> ll=lpeg.locale()
> p=ll.alpha*2
> l.print(p)
[]
00: set [(41-5a)(61-7a)]-> FAIL
05: any * 2-> FAIL
06: end
> =p.match("099")
nil
> =p.match("EST")
4
> =p.match("E99")
4
你想要的模式是:
> function patcount(pat, min, max)
>> return -pat^(max + 1) * pat^min
>> end
> p=patcount(ll.alpha, 3, 3)
> lpeg.print(p)
[]
00: set [(41-5a)(61-7a)]-> 27
05: choice -> 27 (1)
06: set [(41-5a)(61-7a)]-> FAIL
11: set [(41-5a)(61-7a)]-> FAIL
16: set [(41-5a)(61-7a)]-> FAIL
21: span [(41-5a)(61-7a)]
26: failtwice
27: set [(41-5a)(61-7a)]-> FAIL
32: set [(41-5a)(61-7a)]-> FAIL
37: set [(41-5a)(61-7a)]-> FAIL
42: span [(41-5a)(61-7a)]
47: end
> =p:match("EST")
4
> return p:match("ES")
nil
> return p:match("ESTT")
nil
> return p:match("099")
nil
> return p:match("E99")
nil
相关文档位是-patt
.
至于l.alpha*2
手册中此引用解释的语法。
所有期望模式作为参数的操作也可以接收字符串、表格、数字、布尔值或函数,它们根据函数 lpeg.P 的规则转换为模式。
也就是说,当操作数之一已经是模式时,运算符会将非模式转换为模式。
LpegRecipes lua-users.org wiki 页面上还有“匹配固定数量的模式重复”部分(和链接) 。(但我根本没有看过那个实现,它看起来比我上面的更复杂。)