当前位置: 首页 > 图文教程 > 网络编程 > 正则表达式 > 左右若干数字验证的正则表达式

正则表达式
[原创]正则匹配后面非指定字符的正则
一个关于正则表达式的问题
代替正则:HyperScriptExpression联合开发倡议公告
[原创]正则替换字符串功能
[原创]java 正则表达式基础,实例学习资料收集大全
web标准知识:丰富段落里的标签
js判断是否有6个连续数字的字符串的正则
正则表达式中的反向预搜索实现
精通 JavaScript中的正则表达式手机整理 推荐
取图片路径的正则
UBB 转换函数演示 (经典论坛)
pjblog的ubbcodeasp文件
PBlog2 公用JS代码
用的ubb转换
密码强度检测函数(正则)
正则表达式工具 Match Tracer
编写采集规则的好帮手—RegexBuddy 下载,正则不再难
正则表达式30分钟入门教程 v2.1版
asp 图片正则 替换,替换前检查图片是不是本地地址的方法
正则表达式口诀 正则表达式学习工具

左右若干数字验证的正则表达式


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-01-10   浏览: 48 ::
收藏到网摘: n/a

求一个正则表达式,要求左边若干数字,中间间隔号-,右边若干数字,左右数字总个数不超过20。希望能直接用,不用其它函数进行计算。 ?<=和?=和?:这三种各是什么意思 ,请讲解一下。
你的答案很精辟,谢谢。
给你写了一段示例,用javascript写的,你说的左右数字总个数不超过20,加上“-”即字符串总长度不超过21。如下:

[Ctrl+A 全选 提示:你可先修改部分代码,再按运行]

测试后能满足你的要求。
你想问的应该是以下四个环视结构。它们不匹配任何具体的字符,只匹配一个位置,就像“^”和“$”匹配字符串的起始和结束位置。
(?=...) 正向肯定环视。其中“...”是一个正则表达式,表示在当前位置的右边的字符必须被“...”所匹配。
(?!...) 正向否定环视。表示当前位置右边的内容必须不能被“...”所匹配。
(?<=...)和(?<!...)分别是反向肯定环视和反向否定环视,只不过方向是左边。
至于(?:),它与普通的括号()功能相同,区别是它不会将子匹配储存起来。某些情况下使用(?:)能提高正则表达式的效率。
再来说说表达式“/^(?=.{3,21}$)\d+-\d+$/”:
^(?=.{3,21}$) 规定了从字符串的起始位置开始,后面有3-21个任意字符,接着就是字符串的结束了。
\d+-\d+$ 这个是你的题目要求,没什么好说的了吧。