`
sty2008boy
  • 浏览: 302372 次
  • 性别: Icon_minigender_1
  • 来自: 太原
社区版块
存档分类
最新评论

全面的正则表达式

阅读更多
"^\d+$"  //非负整数(正整数 + 0)
"^[0-9]*[1-9][0-9]*$"  //正整数
"^((-\d+)|(0+))$"  //非正整数(负整数 + 0)
"^-[0-9]*[1-9][0-9]*$"  //负整数
"^-?\d+$"    //整数
"^\d+(\.\d+)?$"  //非负浮点数(正浮点数 + 0)
"^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$"  //正浮点数
"^((-\d+(\.\d+)?)|(0+(\.0+)?))$"  //非正浮点数(负浮点数 + 0)
"^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$"  //负浮点数
"^(-?\d+)(\.\d+)?$"  //浮点数
"^[A-Za-z]+$"  //由26个英文字母组成的字符串
"^[A-Z]+$"  //由26个英文字母的大写组成的字符串
"^[a-z]+$"  //由26个英文字母的小写组成的字符串
"^[A-Za-z0-9]+$"  //由数字和26个英文字母组成的字符串
"^\w+$"  //由数字、26个英文字母或者下划线组成的字符串
"^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$"    //email地址
"^[a-zA-z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$"  //url一、验证类1、数字验证内    1.1 整数        /^(-|\+)?\d+$/.test(str)    1.2 大于0的整数 (用于传来的ID的验证)        /^\d+$/.test(str)    1.3 负整数的验证        /^-\d+$/.test(str)2、时间类    2.1 短时间,形如 (13:04:06)        function isTime(str)        {          var a = str.match(/^(\d{1,2})(:)?(\d{1,2})\2(\d{1,2})$/);          if (a == null) {alert('输入的参数不是时间格式'); return false;}          if (a[1]>24 || a[3]>60 || a[4]>60)          {            alert("时间格式不对");            return false          }          return true;        }    2.2 短日期,形如 (2003-12-05)        function strDateTime(str)        {           var r = str.match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/);            if(r==null)return false;            var d= new Date(r[1], r[3]-1, r[4]);            return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]);        }    2.3 长时间,形如 (2003-12-05 13:04:06)        function strDateTime(str)        {          var reg = /^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/;           var r = str.match(reg);           if(r==null)return false;           var d= new Date(r[1], r[3]-1,r[4],r[5],r[6],r[7]);           return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]&&d.getHours()==r[5]&&d.getMinutes()==r[6]&&d.getSeconds()==r[7]);        }    2.4 只有年和月。形如(2003-05,或者2003-5)    2.5 只有小时和分钟,形如(12:03)3、表单类    3.1 所有的表单的值都不能为空        <input onblur="if(this.value.replace(/^\s+|\s+$/g,'')=='')alert('不能为空!')">    3.2 多行文本框的值不能为空。    3.3 多行文本框的值不能超过sMaxStrleng    3.4 多行文本框的值不能少于sMixStrleng    3.5 判断单选框是否选择。    3.6 判断复选框是否选择.    3.7 复选框的全选,多选,全不选,反选    3.8 文件上传过程中判断文件类型4、字符类    4.1 判断字符全部由a-Z或者是A-Z的字字母组成        <input onblur="if(/[^a-zA-Z]/g.test(this.value))alert('有错')">    4.2 判断字符由字母和数字组成。        <input onblur="if(/[^0-9a-zA-Z]/g.test(this.value))alert('有错')">    4.3 判断字符由字母和数字,下划线,点号组成.且开头的只能是下划线和字母        /^([a-zA-z_]{1})([\w]*)$/g.test(str)    4.4 字符串替换函数.Replace();5、浏览器类    5.1 判断浏览器的类型        window.navigator.appName    5.2 判断ie的版本        window.navigator.appVersion    5.3 判断客户端的分辨率        window.screen.height;    window.screen.width;  6、结合类    6.1 email的判断。        function ismail(mail)        {          return(new RegExp(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/).test(mail));        }    6.2 手机号码的验证    6.3 身份证的验证        function isIdCardNo(num)        {          if (isNaN(num)) {alert("输入的不是数字!"); return false;}          var len = num.length, re;           if (len == 15)            re = new RegExp(/^(\d{6})()?(\d{2})(\d{2})(\d{2})(\d{3})$/);          else if (len == 18)            re = new RegExp(/^(\d{6})()?(\d{4})(\d{2})(\d{2})(\d{3})(\d)$/);          else {alert("输入的数字位数不对!"); return false;}          var a = num.match(re);          if (a != null)          {            if (len==15)            {              var D = new Date("19"+a[3]+"/"+a[4]+"/"+a[5]);              var B = D.getYear()==a[3]&&(D.getMonth()+1)==a[4]&&D.getDate()==a[5];            }            else            {              var D = new Date(a[3]+"/"+a[4]+"/"+a[5]);              var B = D.getFullYear()==a[3]&&(D.getMonth()+1)==a[4]&&D.getDate()==a[5];            }            if (!B) {alert("输入的身份证号 "+ a[0] +" 里出生日期不对!"); return false;}          }          return true;        }
//校验是否全由数字组成function isDigit(s){var patrn=/^[0-9]{1,20}$/;if (!patrn.exec(s)) return falsereturn true}
//校验登录名:只能输入5-20个以字母开头、可带数字、“_”、“.”的字串function isRegisterUserName(s){var patrn=/^[a-zA-Z]{1}([a-zA-Z0-9]|[._]){4,19}$/;if (!patrn.exec(s)) return falsereturn true}
//校验用户姓名:只能输入1-30个以字母开头的字串function isTrueName(s){var patrn=/^[a-zA-Z]{1,30}$/;if (!patrn.exec(s)) return falsereturn true}
//校验密码:只能输入6-20个字母、数字、下划线function isPasswd(s){var patrn=/^(\w){6,20}$/;if (!patrn.exec(s)) return falsereturn true}
//校验普通电话、传真号码:可以“+”开头,除数字外,可含有“-”function isTel(s){//var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?(\d){1,12})+$/;var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/;if (!patrn.exec(s)) return falsereturn true}
//校验手机号码:必须以数字开头,除数字外,可含有“-”function isMobil(s){var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/;if (!patrn.exec(s)) return falsereturn true}
//校验邮政编码function isPostalCode(s){//var patrn=/^[a-zA-Z0-9]{3,12}$/;var patrn=/^[a-zA-Z0-9 ]{3,12}$/;if (!patrn.exec(s)) return falsereturn true}
//校验搜索关键字function isSearch(s){var patrn=/^[^`~!@#$%^&*()+=|\\\][\]\{\}:;\'\,.<>/?]{1}[^`~!@$%^&()+=|\\\][\]\{\}:;\'\,.<>?]{0,19}$/;if (!patrn.exec(s)) return falsereturn true}
function isIP(s) //by zergling{var patrn=/^[0-9.]{1,20}$/;if (!patrn.exec(s)) return falsereturn true}
//取出字符串前后的空格var strString = " aaaaa     ";strString = strString.replace(/(^[\s]*)|([\s]*$)/g, "");
在使用 RegularExpressionValidator 验证控件时常用的验证功能及其验证表达式介绍如下:
只能输入数字:"^[0-9]*$"
只能输入 n 位的数字:"^\d{n}$"
只能输入至少 n 位的数字:"^\d{n,}$"
只能输入 m ~ n 位的数字:"^\d{m,n}$"
只能输入零和非零开头的数字:"^(0|[1-9][0-9]*)$"
只能输入有两位小数的正实数:"^[0-9]+(.[0-9]{2})?$"
只能输入有 1~3 位小数的正实数:"^[0-9]+(.[0-9]{1,3})?$"
只能输入非零的正整数:"^\+?[1-9][0-9]*$"
只能输入非零的负整数:"^\-[1-9][0-9]*$"
只能输入长度位 3 的字符:"^.{3}$"
只能输入由 26 个英文字母组成的字符串:"^[A-Za-z]+$"
只能输入由 26 个大写英文字母组成的字符串:"^[A-Z]+$"
只能输入由 26 个小写英文字母组成的字符串:"^[a-z]+$"
只能输入由数字和 26 个英文字母组成的字符串:"^[A-Za-z0-9]+$"
只能输入由数字、26个英文字母或者下划线组成的字符串:"^\w+$"
验证用户密码: "^[a-zA-Z]\w{5,17}$" 正确格式位:以字母开头,长度在6~18之间,只能包含字符、数字和下划线
验证是否含有 ^%&',;=?$\"等字符:"[^%&',;=?$\x22]+"
只能输入汉字:"^[\u4e00-\u9fa5]{0,}$"
验证 Email 地址:"^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$"
验证 InternetURL:"^http://([\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?$"
分享到:
评论

相关推荐

    正则表达式 必知必会 pdf

    本书基于各种实用场景,从基础的文本匹配开始,逐步深入到回溯引用、条件性求值以及前后查找等高级特性,使得读者能够系统、全面地掌握正则表达式的使用方法,并将其应用于解决实际问题中。 书中介绍的正则表达式...

    精通正则表达式(第三版)简体中文版

    《精通正则表达式(第三版)简体中文版》是一本全面介绍正则表达式技术的书籍,不仅覆盖了基本语法和高级特性,还详细讲解了在不同编程环境下的具体应用方法。对于想要深入学习并掌握正则表达式技术的读者来说,本书...

    Delphi2010正则表达式插件

    这款名为"Delphi 2010正则表达式插件"的组件,其核心是基于Perl Compatible Regular Expressions (PCRE)库,这是一款广泛使用的正则表达式库,它对正则表达式的支持非常全面,提供了丰富的功能和语法。在Delphi 2010...

    比较全面的正则表达式

    ### 正则表达式知识点详解 #### 一、概述 正则表达式是一种强大的文本处理工具,能够帮助我们在文本中查找、替换或提取特定模式的字符串。本文将根据提供的部分内容,详细解读各种常见且实用的正则表达式,并对每个...

    强大的正则表达式生成工具 C#版

    C#作为.NET框架的一部分,提供了全面支持正则表达式的类库,使得开发人员能够方便地利用正则表达式进行复杂的文本处理任务。在这个“强大的正则表达式生成工具 C#版”中,我们可以期待一个专为C#开发者设计的高效、...

    精通正则表达式中文版英文版_中文版为扫描版

    正则表达式是一种强大的文本处理工具,用于在字符串中匹配、查找、替换或者提取特定模式。它是编程语言中不可或缺的一部分,特别是在处理文本数据时。"精通正则表达式"是一本备受推崇的书籍,由Jeffrey E. F. Friedl...

    C#字符串和正则表达式参考手册

    在编程领域,C#语言以其强大的功能和易用性深受开发者喜爱。特别是在处理文本操作时,字符串和正则表达式...通过深入阅读《C#字符串和正则表达式参考手册》,你将能够更全面地理解这两个主题,并将其运用到日常工作中。

    正则表达式判断密码强度

    总结来说,正则表达式是评估和验证密码强度的有效工具,但需要结合其他安全措施,以确保密码策略的全面性和安全性。同时,对密码周期的管理也是保护账户安全的重要一环,这通常通过后台管理系统来实现。

    最常用的一些正则表达式和验证正则表达式

    验证电子邮件地址通常需要一个复杂但全面的正则表达式,以确保格式正确。以下是一个常见的C#中使用的正则表达式: ```regex ^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$ ``` 这个表达式会匹配大部分标准...

    精通正则表达式(第三版)

    十年三版,再显王者风范,近30年开发经验的智慧结晶,深入理解正则表达式,彻底修炼基本功,全球第一本全面深入讲解正则表达式的经典巨著,《程序员》杂志技术主编孟岩鼎力推荐。 专家点评:《精通正则表达式》是...

    正则表达式测试文件

    这些字符串可能涵盖了各种情况,如常见的单词、日期格式、邮箱地址、电话号码等,以全面验证正则表达式的有效性。 测试文件的子文件名“zhenzebdcs”可能是某种编码或者随机字符串,具体含义可能需要查看文件内容...

    正则表达式必知必会_正则表达式_

    正则表达式是一种威力无比强大的武器,几乎在所有的程序设计语言里...每章都为读者准备了许多简明又实用的示例,有助于全面、系统、快速掌握正则表达式,并运用它们去解决实际问题。本书适合各种语言和平台的开发人员。

    Jmeter正则表达式提取器

    熟练掌握正则表达式的使用和提取器的配置,能极大地提高测试的效率和准确性,确保测试的全面性和可靠性。因此,对于任何涉及接口测试的工程师来说,理解和应用Jmeter正则表达式提取器是必备技能之一。

    易语言正则表达式调试工具

    3. **测试用例**:准备全面的测试用例,确保正则表达式在各种情况下的表现都符合预期。 4. **优化性能**:对于性能敏感的应用,应考虑正则表达式的执行效率,避免过于复杂的正则表达式。 总的来说,易语言正则...

    最实用最全面的正则表达式

    本文将详细介绍一系列实用且全面的正则表达式,旨在帮助开发者在实际工作中更加高效地完成相关任务。 #### 二、匹配中文字符 **正则表达式**: `[u4e00-u9fa5]` - **应用场景**: 当需要验证或匹配中文字符时,此...

    神奇的匹配-正则表达式之旅

    并基于目前流行的程序语言和应用环境-如c、asp.net、jsp、或php 全面介绍了创建正则表达式的方法 以及正则表达式在web环境中的各种应用。 【电子版来自互联网,仅供预览及学习交流使用,不可用于商业用途,如有版权...

    正则表达式工具包

    "正则表达式工具包"显然是一款专为正则表达式开发和测试设计的应用程序,它提供了全面的功能,以满足所有正则表达式相关的开发需求。 RegexBuddy4.exe 是这个工具包的主要程序文件,很可能是一个名为 "RegexBuddy" ...

    JavaScript正则表达式迷你书

    综上所述,《JavaScript正则表达式迷你书》是一本系统全面介绍JavaScript正则表达式的教材,适合希望深入了解和应用JavaScript正则表达式的开发者学习。通过对书中的案例和知识点的学习与实践,可以提高在JavaScript...

Global site tag (gtag.js) - Google Analytics