我需要找到一个只允许字母数字的reg ex。到目前为止,我尝试的每个人都只在字符串是字母数字的情况下工作,意思是既包含字母又包含数字。我只想要一个既允许其中一种,又不要求两者兼得的。
当前回答
这是可行的
^(?=.*[a-zA-Z])(?=.*[0-9])[a-zA-Z0-9]+$
它只接受字母数字字符单独: 通过的测试用例:
dGgs1s23 - valid
12fUgdf - valid,
121232 - invalid,
abchfe - invalid,
abd()* - invalid,
42232^5$ - invalid
or
你也可以试试这个。这个表达式至少满足一个数字和一个字符,而不满足其他特殊字符
^(?=.*[0-9])(?=.*[a-zA-Z])([a-zA-Z0-9]+)$
在angular中可以这样测试:
$scope.str = '12fUgdf';
var pattern = new RegExp('^(?=.*[0-9])(?=.*[a-zA-Z])([a-zA-Z0-9]+)$');
$scope.testResult = pattern.test($scope.str);
恰好演示
参考:Angularjs中字母数字的正则表达式
其他回答
似乎许多用户已经注意到,除非我们严格使用英语,否则这些正则表达式几乎肯定会失败。但我认为有一种不受限制的简单方法。
复制你的字符串在所有大写 用小写字母复制一份
在这些字符串中匹配的任何字符本质上肯定不是字母。
let copy1 = originalString.toUpperCase();
let copy2 = originalString.toLowerCase();
for(let i=0; i<originalString.length; i++) {
let bIsAlphabetic = (copy1[i] != copy2[i]);
}
此外,您还可以通过查找数字0到9来检测数字。
^\s*([0-9a-zA-Z]*)\s*$
或者,如果你想要最少一个字符:
^\s*([0-9a-zA-Z]+)\s*$
方括号表示一组字符。^是输入的开始。$是输入的结束符(或换行符,取决于您的选项)。\s是空格。
前面和后面的空格是可选的。
圆括号是分组操作符,允许您提取所需的信息。
编辑:删除了我的错误使用\w字符集。
/^[a-z0-9]+$/i
^ Start of string
[a-z0-9] a or b or c or ... z or 0 or 1 or ... 9
+ one or more times (change to * to allow empty string)
$ end of string
/i case-insensitive
更新(支持通用字符)
如果您需要这个regexp支持通用字符,您可以在这里找到unicode字符列表。
美国小妞example: / ^(黑a-zA-Z0-9 \ u0600——地球,随便\ u06FF u0660——\ u0669 \ u06F0——\ u06F9 _. -铝+)美元/
这将支持波斯语。
甚至比Gayan Dissanayake指出的还要好。
/^[-\w\s]+$/
现在^[a-zA-Z0-9]+$可以表示为^\w+$
你可能想用\s代替空格。注意,\s负责空格,而不仅仅是一个空格字符。
JAVASCRIPT只接受数字,字母和特殊字符
document.getElementById("onlynumbers").onkeypress = function (e) { onlyNumbers(e.key, e) }; document.getElementById("onlyalpha").onkeypress = function (e) { onlyAlpha(e.key, e) }; document.getElementById("speclchar").onkeypress = function (e) { speclChar(e.key, e) }; function onlyNumbers(key, e) { var letters = /^[0-9]/g; //g means global if (!(key).match(letters)) e.preventDefault(); } function onlyAlpha(key, e) { var letters = /^[a-z]/gi; //i means ignorecase if (!(key).match(letters)) e.preventDefault(); } function speclChar(key, e) { var letters = /^[0-9a-z]/gi; if ((key).match(letters)) e.preventDefault(); } <html> <head></head> <body> Enter Only Numbers: <input id="onlynumbers" type="text"> <br><br> Enter Only Alphabets: <input id="onlyalpha" type="text" > <br><br> Enter other than Alphabets and numbers like special characters: <input id="speclchar" type="text" > </body> </html>