问题描述
我已经坚持24小时了。仍在尝试满足约束条件以完成这项工作。我已经尝试了各种方法,但对于regex tho还是一个新手。我正在用JavaScript编写这作为freeCodeCamp的挑战。
对于(1.)我做了/^[a-zA-Z0-9]/
对于(2.)我做了/[0-9]*$/
已经在(1.)中做到了
for(4。)(对此不太确定)/ .. / ...尝试将所有这些组合到单个regex语句中
我做到了:/^[a-zA-Z0-9][0-9]*$../
解决方法
您可以使用否定的前瞻来断言该字符串不是以char a-zA-Z开头,后跟一个可选数字。
然后以1个以上的字符a-zA-Z开始比赛,并以可选的数字结束比赛。
^(?![A-Za-z]\d?$)[a-zA-Z]+\d*$
说明
-
^
字符串的开头 -
(?![A-Za-z]\d?$)
负向查找,请断言一个字符a-zA-Z,后接可选数字和字符串结尾 -
[a-zA-Z]+\d*
匹配1+字符a-zA-Z,后跟可选数字,以使字符串不能以数字开头 -
$
字符串结尾
const regex = /^(?![A-Za-z]\d?$)[a-zA-Z]+\d*$/;
[
"tt","tt2","test","a11","t2","t","1","t1t"
].forEach(s => console.log(`${s} ==> ${regex.test(s)}`));
,
就答案而言,对于一只新蜜蜂来说可能并不容易 这确实是一样的事情
^([a-z]{2,}|[a-z][0-9]{2,})[0-9]*$
这样^
表示字符串的开始位置,表示字符串的开始
()
用于定义组,在这种情况下定义的组是所有小写字母,最小长度为2,因为{}
用于指定字符串的长度
然后在此处使用的管道符号|
表示“或”,然后下一个表达式为[a-z][0-9]{2,}
,表示所有小写字母,后跟一个最小长度为2的整数。
最后,在该组之后,它们可以出现零个或多个整数,可以使用*
符号强制执行,而$
表示字符串的结尾
因此,此正则表达式如下:从字符串的开头,它应以最小长度为2的小写字母或一个小写字母和一个数字开头,但数字长度不能小于2,然后可以有一系列整数或数字后跟它们,否则您将没有
这是一个非常直接且受限制的解决方案,可能应用于学习目的或仅在需要时使用,在现实生活中的应用程序中可能需要更灵活的正则表达式
更多细分:
^([a-z]{2,})[0-9]*$
'^`声明行首的位置
第一捕获组([a-z]{2,})
第一种选择[a-z]{2,}
匹配以下列表中存在的单个字符
[a-z]{2,}
{2,}
量词-匹配2次到无限次,并尽可能多地匹配,并根据需要进行回馈(贪婪)
a-z
中的一个字符,介于'a'(索引97)和'z'(索引122)(区分大小写)
第二种替代方法[a-z][0-9]{2,}
匹配[a-z]
a-z在(索引97)和z(索引122)之间的单个字符(区分大小写)
匹配[0-9]{2,}
下面的列表中存在的单个字符
{2,}
量词-匹配2次到无限次,并尽可能多地匹配,并根据需要返回(贪婪)
0-9单个字符,介于0(索引48)和9(索引57)(区分大小写)之间
匹配[0-9]以下列表中存在的单个字符*
*
量词-在零次和无限制次数之间进行匹配,并尽可能多地匹配,并根据需要进行回馈(贪婪)
0-9
的单个字符,介于0(索引48)和9(索引57)(区分大小写)之间
$
在行尾声明位置
import re
pattern="^([a-z]{2,})[0-9]*$"
if re.match(pattern,input()):
print("Ok")
else:
print("Not ok")