热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

日常收集整理正则表达式验证大全

这篇文章主要介绍了日常收集整理正则表达式验证大全的相关资料,需要的朋友可以参考下

常用正则表达式大全!(例如:匹配中文、匹配html)

匹配中文字符的正则表达式: [u4e00-u9fa5]   

评注:匹配中文还真是个头疼的事,有了这个表达式就好办了  

 匹配双字节字符(包括汉字在内):[^x00-xff]  

 评注:可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)  

 匹配空白行的正则表达式:ns*r  

 评注:可以用来删除空白行

 匹配HTML标记的正则表达式:<(S*&#63;)[^>]*>.*&#63;|<.*&#63; />  

 评注:网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为力  

 匹配首尾空白字符的正则表达式:^s*|s*$   

评注:可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式   

匹配Email地址的正则表达式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*  

 评注:表单验证时很实用

 匹配网址URL的正则表达式:[a-zA-z]+://[^s]*   

评注:网上流传的版本功能很有限,上面这个基本可以满足需求   

匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):

^[a-zA-Z][a-zA-Z0-9_]{4,15}$  

 评注:表单验证时很实用   

匹配国内电话号码:d{3}-d{8}|d{4}-d{7}  

 评注:匹配形式如 0511-4405222 或 021-87888822  

 匹配腾讯QQ号:[1-9][0-9]{4,}  

 评注:腾讯QQ号从10000开始  

 匹配中国邮政编码:[1-9]d{5}(&#63;!d)  

 评注:中国邮政编码为6位数字

 匹配身份证:d{15}|d{18}  

 评注:中国的身份证为15位或18位

  匹配ip地址:d+.d+.d+.d+

  评注:提取ip地址时有用  

 匹配特定数字:   

^[1-9]d*$    //匹配正整数  

 ^-[1-9]d*$   //匹配负整数  

 ^-&#63;[1-9]d*$   //匹配整数  

 ^[1-9]d*|0$  //匹配非负整数(正整数 + 0)  

 ^-[1-9]d*|0$   //匹配非正整数(负整数 + 0)  

 ^[1-9]d*.d*|0.d*[1-9]d*$   //匹配正浮点数  

 ^-([1-9]d*.d*|0.d*[1-9]d*)$  //匹配负浮点数  

 ^-&#63;([1-9]d*.d*|0.d*[1-9]d*|0&#63;.0+|0)$  //匹配浮点数  

 ^[1-9]d*.d*|0.d*[1-9]d*|0&#63;.0+|0$   //匹配非负浮点数(正浮点数 + 0)  

 ^(-([1-9]d*.d*|0.d*[1-9]d*))|0&#63;.0+|0$  //匹配非正浮点数(负浮点数 + 0)

  评注:处理大量数据时有用,具体应用时注意修正

 匹配特定字符串:  

 ^[A-Za-z]+$  //匹配由26个英文字母组成的字符串   

^[A-Z]+$  //匹配由26个英文字母的大写组成的字符串  

 ^[a-z]+$  //匹配由26个英文字母的小写组成的字符串

 ^[A-Za-z0-9]+$  //匹配由数字和26个英文字母组成的字符串   

^w+$   //匹配由数字、26个英文字母或者下划线组成的字符串  

 在使用RegularExpressionValidator验证控件时的验证功能及其验证表达式介绍如下:  

 只能输入数字:“^[0-9]*$”  

 只能输入n位的数字:“^d{n}$”  

 只能输入至少n位数字:“^d{n,}$”  

 只能输入m-n位的数字:“^d{m,n}$”  

 只能输入零和非零开头的数字:“^(0|[1-9][0-9]*)$”  

 只能输入有两位小数的正实数:“^[0-9]+(.[0-9]{2})&#63;$”  

 只能输入有1-3位小数的正实数:“^[0-9]+(.[0-9]{1,3})&#63;$”  

 只能输入非零的正整数:“^+&#63;[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之间,只能包含字符、数字和下划线。   

验证是否含有^%&'',;=&#63;$"等字符:“[^%&'',;=&#63;$x22]+”  

 只能输入汉字:“^[u4e00-u9fa5],{0,}$”  

 验证Email地址:“^w+[-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$”  

 验证InternetURL:“^http://([w-]+.)+[w-]+(/[w-./&#63;%&=]*)&#63;$”   

验证电话号码:“^((d{3,4})|d{3,4}-)&#63;d{7,8}$”  

 正确格式为:“XXXX-XXXXXXX”,“XXXX-XXXXXXXX”,“XXX-XXXXXXX”,   “XXX-XXXXXXXX”,“XXXXXXX”,“XXXXXXXX”。   

验证身份证号(15位或18位数字):“^d{15}|d{}18$”

验证一年的12个月:“^(0&#63;[1-9]|1[0-2])$”正确格式为:“01”-“09”和“1”“12”   

验证一个月的31天:“^((0&#63;[1-9])|((1|2)[0-9])|30|31)$”   

正确格式为:“01”“09”和“1”“31”。  

 匹配中文字符的正则表达式: [u4e00-u9fa5]  

 匹配双字节字符(包括汉字在内):[^x00-xff]   

匹配空行的正则表达式:n[s| ]*r  

 匹配HTML标记的正则表达式:/<(.*)>.*|<(.*) />/   

匹配首尾空格的正则表达式:(^s*)|(s*$)

 匹配Email地址的正则表达式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*

 匹配网址URL的正则表达式:http://([w-]+.)+[w-]+(/[w- ./&#63;%&=]*)&#63;

 (5)应用:利用正则表达式限制网页表单里的文本框输入内容  

 用正则表达式限制只能输入中文:

代码如下:

Onkeyup="value=value.replace(/[^u4E00-u9FA5]/g,'') "Onbeforepaste="clipboardData.setData(''text'',clipboardData.getData(''text'').replace(/[^u4E00-u9FA5]/g,''))"   

用正则表达式限制只能输入全角字符:

代码如下:

Onkeyup="value=value.replace(/[^uFF00-uFFFF]/g,'') "Onbeforepaste="clipboardData.setData(''text'',clipboardData.getData(''text'').replace(/[^uFF00-uFFFF]/g,''))"
  

用正则表达式限制只能输入数字:

代码如下:

Onkeyup="value=value.replace(/[^d]/g,'') "Onbeforepaste= "clipboardData.setData(''text'',clipboardData.getData(''text'').replace(/[^d]/g,''))"   

用正则表达式限制只能输入数字和英文:

代码如下:

Onkeyup="value=value.replace(/[W]/g,'') "Onbeforepaste="clipboardData.setData(''text'',clipboardData.getData(''text'').replace(/[^d]/g,''

用途:判断是否是日期 输入:date:日期;fmt:日期格式 返回:如果通过验证返回true,否则返回false

 */ function isDate( date, fmt ) { 


if (fmt==null) fmt="yyyyMMdd"; 
var yIndex = fmt.indexOf("yyyy"); 
if(yIndex==-1) 
return false; 
var year = date.substring(yIndex,yIndex+4); 
var mIndex = fmt.indexOf("MM"); 
if(mIndex==-1)
return false; 
var mOnth= date.substring(mIndex,mIndex+2); 
var dIndex = fmt.indexOf("dd"); 
if(dIndex==-1)
return false; 
var day = date.substring(dIndex,dIndex+2); 
if(!isNumber(year)||year>"2100" || year<"1900") 
return false; 
if(!isNumber(month)||month>"12" || month<"01") 
return false;
if(day>getMaxDay(year,month) || day<"01") 
return false; 
return true; 
} 
function getMaxDay(year,month) { 
if(mOnth==4||mOnth==6||mOnth==9||mOnth==11) return "30"; 
if(mOnth==2) i
f(year%4==0&&year%100!=0 || year%400==0) 
return "29"; 
else return "28"; 
return "31"; 
}

正则表达式验证大全小编就给大家介绍到这里,希望对大家有所帮助!


推荐阅读
  • Vue 2 中解决页面刷新和按钮跳转导致导航栏样式失效的问题
    本文介绍了如何通过配置路由的 meta 字段,确保 Vue 2 项目中的导航栏在页面刷新或内部按钮跳转时,始终保持正确的 active 样式。具体实现方法包括设置路由的 meta 属性,并在 HTML 模板中动态绑定类名。 ... [详细]
  • 本文探讨了如何通过最小生成树(MST)来计算严格次小生成树。在处理过程中,需特别注意所有边权重相等的情况,以避免错误。我们首先构建最小生成树,然后枚举每条非树边,检查其是否能形成更优的次小生成树。 ... [详细]
  • 程序员妻子吐槽:丈夫北漂8年终薪3万,存款情况令人意外
    一位程序员的妻子在网上分享了她丈夫在北京工作八年的经历,月薪仅3万元,存款情况却出乎意料。本文探讨了高学历人才在大城市的职场现状及生活压力。 ... [详细]
  • 国内BI工具迎战国际巨头Tableau,稳步崛起
    尽管商业智能(BI)工具在中国的普及程度尚不及国际市场,但近年来,随着本土企业的持续创新和市场推广,国内主流BI工具正逐渐崭露头角。面对国际品牌如Tableau的强大竞争,国内BI工具通过不断优化产品和技术,赢得了越来越多用户的认可。 ... [详细]
  • 本文详细分析了JSP(JavaServer Pages)技术的主要优点和缺点,帮助开发者更好地理解其适用场景及潜在挑战。JSP作为一种服务器端技术,广泛应用于Web开发中。 ... [详细]
  • QBlog开源博客系统:Page_Load生命周期与参数传递优化(第四部分)
    本教程将深入探讨QBlog开源博客系统的Page_Load生命周期,并介绍一种简洁的参数传递重构方法。通过视频演示和详细讲解,帮助开发者更好地理解和应用这些技术。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • PyCharm下载与安装指南
    本文详细介绍如何从官方渠道下载并安装PyCharm集成开发环境(IDE),涵盖Windows、macOS和Linux系统,同时提供详细的安装步骤及配置建议。 ... [详细]
  • 在 Windows 10 中,F1 至 F12 键默认设置为快捷功能键。本文将介绍几种有效方法来禁用这些快捷键,并恢复其标准功能键的作用。请注意,部分笔记本电脑的快捷键可能无法完全关闭。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • 本周信息安全小组主要进行了CTF竞赛相关技能的学习,包括HTML和CSS的基础知识、逆向工程的初步探索以及整数溢出漏洞的学习。此外,还掌握了Linux命令行操作及互联网工作原理的基本概念。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • CSS 布局:液态三栏混合宽度布局
    本文介绍了如何使用 CSS 实现液态的三栏布局,其中各栏具有不同的宽度设置。通过调整容器和内容区域的属性,可以实现灵活且响应式的网页设计。 ... [详细]
  • 本文探讨了如何像程序员一样思考,强调了将复杂问题分解为更小模块的重要性,并讨论了如何通过妥善管理和复用已有代码来提高编程效率。 ... [详细]
author-avatar
李新绿寧惠_330
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有