对正则表达式的一些记录
对正则表达式的一些记录
前言
这段时间由于个人事比较多,所以没有好好记录一下一些内容,今天突然想起来对于正则表达式这块还是没有一个认知,所以拎出来记录一下关于它的一些内容
一、什么是正则表达式?
其实就像我们搜索以及用什么东西时候的规则,“正”字可以理解为经常出现、通用的意思;“则”可以理解为有规则的,而这个表达式的话,总体意思就是使用我们通用的规则去匹配文本。(去让计算机认识这种规则),所以它就是一门专门用于字符串处理的增强语法。
二、为什么要用正则表达式?
主要用于前端校验,JavaScript和Java都支持这种语法(因为个人原因,所以并未对其过多了解),目前是在表单验证时,去准确的判断一个字符串是不是某种固定格式。比如邮箱的验证、手机号的验证等。目的是避免恶意用户的乱输入,保证表单的收集是我们想要的格式!
三、怎么用?
个人主要是在JS中用到,定义方式如下,具体的话可以网上搜教程,这里举个例子。
var reg=/正则表达式/; //正则要用双 / / 包 起来
“//”它们用来指示模式的开始和结束,通过它们可以告诉 JS 解释器它正在处理正则表达式:
3.1 需要记住的特殊符号
^: 以什么开头
$: 以什么结尾
\d: 表示任意一位数字
\w: 表示数字,大小写英文字符,常见的特殊符号。
.: 表示任意内容。
: 可以表示转义
{6}: 表示匹配前面的字符6次。
{n,m}: 匹配前面的字符n到m次。
{n,}: 匹配前面的字符至少n次。
*: 匹配前面的字符0次或多次。
+: 匹配前面的字符至少1次。
?: 匹配前面的字符0次或者1次。
3.2 附录一:常用表达式
1.非负整数 /^\d+$/
2.正整数 /^[0-9][1-9][0-9]$/
3.非正整数 /^((-\d+)|(0+))$/
4.负整数 /^-[0-9][1-9][0-9]$/
5.整数 /^-?\d+$/
6.非负浮点数 /^\d+(.\d+)?$/
7.正浮点数 /^(([0-9]+.[0-9][1-9][0-9])|([0-9][1-9][0-9].[0-9]+)|([0-9][1-9][0-9]))$/
8.非正浮点数 /^((-\d+(.\d+)?)|(0+(.0+)?))$/
9.负浮点数 /^(-(([0-9]+.[0-9][1-9][0-9])|([0-9][1-9][0-9].[0-9]+)|([0-9][1-9][0-9])))$/
10.浮点数 /^(-?\d+)(.\d+)?$/
11.数字 /^\d+(.{1}\d+)?$/
12.由26个英文字母组成的字符串 /^[A-Za-z]+$/
13.由26个英文字母的大写组成的字符串 /^[A-Z]+$/
14.由26个英文字母的小写组成的字符串 /^[a-z]+$/
15.由数字和26个英文字母组成的字符串 /^[A-Za-z0-9]+$/
16.由数字、26个英文字母或者下划线组成的字符串 /^\w+$/
17.匹配所有单字节长度的字符组成的字符串 /^[\x00-\xff]+$/
18.匹配所有双字节长度的字符组成的字符串 /^[^\x00-\xff]+$/
19.字符串是否含有双字节字 /[^\x00-\xff]+/
20.email地址 /^[\w-]+(.[\w-]+)*@[\w-]+(.[\w-]+)+$/
21.url地址 /^[a-zA-z]+://(\w+(-\w+))(.(\w+(-\w+)))(\?\S)?$/
22.匹配中文字符的正则 /[u4e00-u9fa5]/
23.匹配双字节字符(包括汉字在内) /[^x00-xff]/
24.匹配空行的正则 /n[s| ]*r/
25.匹配HTML标记的正则 /<(.)>.|<(.*) />/
26.匹配首尾空格的正则 /(^s)|(s$)/
27.匹配IP地址的正则 /(d+).(d+).(d+).(d+)/
28.验证文件名由字母,数字,下滑线组成 /^((\w+)(.{1})(\w+))$/
29匹配日期(2000-2999)
/^20\d{2}-((0[1-9])|(1[0-2]))-((0[1-9])|([1-2][0-9])|(3([0|1])))$/
30.匹配日期时间
/^(1|2\d{3}-((0[1-9])|(1[0-2]))-((0[1-9])|([1-2][0-9])|(3([0|1]))))( (\d{2}):(\d{2}):(\d{2}))?$/
3.3 附录二:限制文本框输入内容
举例:
只能输入中文:
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,''))"
1.整数或者小数:^[0-9]+.{0,1}[0-9]{0,2}$
2.只能输入数字:"^[0-9]*$"。
3.只能输入n位的数字:"^\d{n}$"。
4.只能输入至少n位的数字:"^\d{n,}$"。
5.只能输入m~n位的数字:。"^\d{m,n}$"
6.只能输入零和非零开头的数字:"^(0|[1-9][0-9]*)$"。
7.只能输入有两位小数的正实数:"^[0-9]+(.[0-9]{2})?$"。
8.只能输入有1~3位小数的正实数:"^[0-9]+(.[0-9]{1,3})?$"。
9.只能输入非零的正整数:"^+?[1-9][0-9]*$"。
10只能输入非零的负整数:"^-[1-9][]0-9"*$。
11.只能输入长度为3的字符:"^.{3}$"。
12.只能输入由26个英文字母组成的字符串:"^[A-Za-z]+$"。
13.只能输入由26个大写英文字母组成的字符串:"^[A-Z]+$"。
14.只能输入由26个小写英文字母组成的字符串:"^[a-z]+$"。
15.只能输入由数字和26个英文字母组成的字符串:"^[A-Za-z0-9]+$"。
16.只能输入由数字、26个英文字母或者下划线组成的字符串:"^\w+$"。
17.验证用户密码:"^[a-zA-Z]\w{5,17}$"正确格式为:以字母开头,长度在6~18之间,只能包含字符、数字和下划线。
18.验证是否含有^%&'',;=?$\"等字符:"[^%&'',;=?$\x22]+"。
19.只能输入汉字:"^[\u4e00-\u9fa5]{0,}$"
20.验证Email地址:"^\w+([-+.]\w+)@\w+([-.]\w+).\w+([-.]\w+)*$"。
21.验证InternetURL:"^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$"。
22.验证电话号码:"^((\d{3,4}-)|\d{3.4}-)?\d{7,8}$"正确格式为:"XXX-XXXXXXX"、"XXXX- XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX"。
23.验证身份证号(15位或18位数字):"^\d{15}|\d{18}$"。
24.验证一年的12个月:"^(0?[1-9]|1[0-2])$"正确格式为:"01"~"09"和"1"~"12"。
25.验证一个月的31天:"^((0?[1-9])|((1|2)[0-9])|30|31)$"正确格式为;"01"~"09"和"1"~"31"。整数或者小数:^[0-9]+.{0,1}[0-9]{0,2}$
3.4 速查可参考文章
四、扩展理解
注:以下博客为参考文章,并未有任何打广告的嫌疑!
掘金 作者:scq000 :正则表达式到底是什么
掘金 作者:Vincent Ko :可能是最好的正则表达式的教程笔记了吧...
博客园 作者:SkySoot :什么是正则表达式
作者:余月七 (yuyueq)
出处:http://www.cnblogs.com/yuyueq
警言: 无论人生上到哪一层台阶,阶下有人在仰望你,阶上亦有人在俯视你。你抬头自卑,低头自得,唯有平视,才能看见真实的自己。
转载请注明原文链接:https://www.cnblogs.com/yuyueq/p/15056811.html
如果觉得这篇文章对你有小小的帮助的话,记得在右下角点个“推荐”哦,博主在此感谢你的支持!
警言: 无论人生上到哪一层台阶,阶下有人在仰望你,阶上亦有人在俯视你。你抬头自卑,低头自得,唯有平视,才能看见真实的自己。
转载请注明原文链接:https://www.cnblogs.com/yuyueq/p/15056811.html
如果觉得这篇文章对你有小小的帮助的话,记得在右下角点个“推荐”哦,博主在此感谢你的支持!