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

正则表达式
[原创]正则匹配后面非指定字符的正则
正则的几个基本概念
php半小时精通正则表达式
一个不错的正则
自己学正则时做的笔记,其实正则也不难哦 php
关于HTML及UBB标记的闭合
用JavaScript实现全局替换,解决$等特殊符号的难题[
正则表达式的基本知识
临时记录:一个正则
一个关于正则表达式的问题
正则表达式不包含align该怎么写
正则表达式话题
Javascrp中几个常用的字符串验证
Js&Vbs正则表达式替换重复的字符
一个验证用户名的正则表达式
正则表达式,只匹配一次下化线!
用JS让文章内容指定的关键字加亮
看到一个JS正则的题
Javascript里的两种使用正则的方法
正则表达式 应用四则

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


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

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

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

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