- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章JavaScript中常用的正则表达式日常整理(全)由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
//校验是否全由数字组成 。
1
2
3
4
5
6
|
function
isDigit(s)
{
var
patrn=/^[0-9]{1,20}$/;
if
(!patrn.exec(s))
return
false
return
true
}
|
。
匹配中文字符的正则表达式: [u4e00-u9fa5] 。
评注:匹配中文还真是个头疼的事,有了这个表达式就好办了 。
匹配双字节字符(包括汉字在内):[^x00-xff] 。
评注:可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1) 。
匹配空白行的正则表达式:ns*r 。
评注:可以用来删除空白行 。
匹配HTML标记的正则表达式:< (S*?)[^>]*>.*?|< .*? /> 。
评注:网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为力 。
匹配首尾空白字符的正则表达式:^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}(?!d) 。
评注:中国邮政编码为6位数字 。
匹配身份证:d{15}|d{18} 。
评注:中国的身份证为15位或18位 。
匹配ip地址:d+.d+.d+.d+ 。
评注:提取ip地址时有用 。
匹配特定数字:
^[1-9]d*$ //匹配正整数 ^-[1-9]d*$ //匹配负整数 ^-?[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*)$ //匹配负浮点数 ^-?([1-9]d*.d*|0.d*[1-9]d*|0?.0+|0)$ //匹配浮点数 ^[1-9]d*.d*|0.d*[1-9]d*|0?.0+|0$ //匹配非负浮点数(正浮点数 + 0) ^(-([1-9]d*.d*|0.d*[1-9]d*))|0?.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})?$” 只能输入有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-./?%&=]*)?$” 。
验证电话号码:“^((d{3,4})|d{3,4}-)?d{7,8}$” 。
正确格式为:“XXXX-XXXXXXX”,“XXXX-XXXXXXXX”,“XXX-XXXXXXX”, “XXX-XXXXXXXX”,“XXXXXXX”,“XXXXXXXX”.
验证身份证号(15位或18位数字):“^d{15}|d{}18$” 。
验证一年的12个月:“^(0?[1-9]|1[0-2])$”正确格式为:“01”-“09”和“1”“12” 。
验证一个月的31天:“^((0?[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- ./?%&=]*)?
(1)应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1) 。
1
|
String.prototype.len=
function
(){
return
this
.replace([^x00-xff]/g,”aa”).length;}
|
(2)应用:javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现 。
1
2
3
4
|
String.prototype.trim =
function
()
{
return
this
.replace(/(^s*)|(s*$)/g, “”);
}
|
。
(3)应用:利用正则表达式分解和转换IP地址 。
1
2
3
4
5
6
7
8
9
10
11
12
|
function
IP2V(ip)
//IP地址转换成对应数值
{
re=/(d+).(d+).(d+).(d+)/g
//匹配IP地址的正则表达式
if
(re.test(ip))
{
return
RegExp.$1*Math.pow(255,3))+RegExp.$2*Math.pow(255,2))+RegExp.$3*255+RegExp.$4*1
}
else
{
throw
new
Error(”Not a valid IP address!”)
}
}
|
(4)应用:从URL地址中提取文件名的javascript程序 。
1
2
|
s=”http:
//www.9499.net/page1.htm”;
s=s.replace(/(.*/){0,}([^.]+).*/ig,”$2″) ;
//Page1.htm
|
。
(5)应用:利用正则表达式限制网页表单里的文本框输入内容 。
用正则表达式限制只能输入中文:onkeyup=”value=”/blog/value.replace(/["^u4E00-u9FA5]/g,”) ” 。
1
|
onbeforepaste=”clipboardData.setData(
'text'
,clipboardData.getData(
'text'
).replace(/[^u4E00-u9FA5]/g,”))”
|
。
用正则表达式限制只能输入全角字符: onkeyup=”value=”/blog/value.replace(/["^uFF00-uFFFF]/g,”) ” 。
onbeforepaste=”clipboardData.setData('text',clipboardData.getData('text').replace(/[^uFF00-uFFFF]/g,”))” 。
用正则表达式限制只能输入数字:onkeyup=”value=”/blog/value.replace(/["^d]/g,”) “onbeforepaste= “clipboardData.setData 。
('text',clipboardData.getData('text').replace(/[^d]/g,”))” 。
用正则表达式限制只能输入数字和英文:onkeyup=”value=”/blog/value.replace(/[W]/g,””) “onbeforepaste=”clipboardData.setData 。
('text',clipboardData.getData('text').replace(/[^d]/g,” 。
中正则表达式,js去掉html标记,去掉字符,截取字符(2009-01-11 10:20:14) 2007-07-08 15:26 。
1,得到网页上的链接地址:
1
|
string matchString = @
"<a[^>]+href=\s*(?:'(?<href>[^']+)'|"
"(?<href>[^"
"]+)"
"|(?<href>[^>\s]+))\s*[^>]*>"
;
|
2,得到网页的标题:
1
|
string matchString = @
"<title>(?<title>.*)</title>"
;
|
3,去掉网页中的所有的html标记:
1
|
string temp = Regex.Replace(html,
"<[^>]*>"
,
""
);
//html是一个要去除html标记的文档
|
。
java 中去掉网页中的所有标签 。
1
|
str = str.replaceAll(
"<[^>]*>"
,
""
);
|
4, string matchString = @"<title>([\S\s\t]*?)</title>",
5,js去掉所有html标记的函数:
1
2
3
4
|
function
delHtmlTag(str)
{
return
str.replace(/<\/?.+?>/g,
""
);
//去掉所有的html标记
}
|
这个可能IE5会错,那用这个,梅花的:
1
2
3
4
|
function
delHtmlTag(str)
{
return
str.replace(/<[^>]+>/g,
""
);
//去掉所有的html标记
}
|
校验登录名:只能输入5-20个以字母开头、可带数字、“_”、“.”的字串 。
1
2
3
4
5
6
|
function
isRegisterUserName(s)
{
var
patrn=/^[a-zA-Z]{1}([a-zA-Z0-9]|[._]){4,19}$/;
if
(!patrn.exec(s))
return
false
return
true
}
|
。
来源:正则匹配空格的问题 。
字符串内字符键有空格,但是空格的数量可能不一致,通过正则将空格的个数统一变为一个.
例如:蓝 色 理 想 。
变成:蓝 色 理 想 。
aobert的正则:
1
2
3
4
5
6
|
<script type=
"text/javascript"
>
var
str=
"蓝 色 理 想"
var
reg=/\s+/g
str = str.replace(reg,
" "
)
document.write(str)
</script>
|
判断字符串是不是由数字组成 。
来源:有没有简单的方法判断字符串由数字组成?
这个正则比较简单,写了一个测试 。
1
2
3
4
5
6
7
8
9
10
|
<script type=
"text/javascript"
>
function
isDigit(str){
var
reg = /^\d*$/;
return
reg.test(str);
}
var
str =
"7654321"
;
document.write(isDigit(str));
var
str =
"test"
;
document.write(isDigit(str));
</script>
|
电话号码正则 。
来源:想问一下关于电话号码的正则判断 。
:求一个验证电话号码的JS正则 。
/^\d{3,4}-\d{7,8}(-\d{3,4})?$/区号必填为3-4位的数字,区号之后用“-”与电话号码连接 。
^\d{3,4}-电话号码为7-8位的数字 。
\d{7,8}分机号码为3-4位的数字,非必填,但若填写则以“-”与电话号码相连接 。
(-\d{3,4})?手机号码正则表达式 正则验证手机号,忽略前面的0,支持130-139,150-159。忽略前面0之后判断它是11位的.
cloeft的正则:
/^0*(13|15)\d{9}$/ ^0*匹配掉开头任意数量的0.
由于手机号码是13任意数字9位,和15任意数字9位,所以可以用(13|15)\d{9}匹配.
测试代码如下:
1
2
3
4
5
6
7
8
9
10
|
function
testReg(reg,str){
return
reg.test(str);
}
var
reg = /^0*(13|15)\d{9}$/;
var
str =
'13889294444'
;
var
str2 =
'12889293333'
;
var
str3 =
'23445567'
;
document.write(testReg(reg,str)+
'<br />'
);
document.write(testReg(reg,str2)+
'<br />'
);
document.write(testReg(reg,str3)+
'<br />'
);
|
使用正则表达式实现删除字符串中的空格:
来源:请问js中有没有去掉空格的函数 。
代码以及测试代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
<script type=
"text/javascript"
>
//删除字符串两侧的空白字符。
function
trim(str){
return
str.replace(/^\s+|\s+$/g,
''
);
}
//删除字符串左侧的空白字符。
function
ltrim(str){
return
str.replace(/^\s+/g,
''
);
}
//删除字符串右侧的空白字符。
function
rtrim(str){
return
str.replace(/\s+$/g,
''
);
}
//以下为测试代码
var
trimTest =
" 123456789 "
;
//前后各有一个空格。
document.write(
'length:'
+trimTest.length+
'<br />'
);
//使用前
document.write(
'ltrim length:'
+ltrim(trimTest).length+
'<br />'
);
//使用ltrim后
document.write(
'rtrim length:'
+rtrim(trimTest).length+
'<br />'
);
//使用rtrim后
document.write(
'trim length:'
+trim(trimTest).length+
'<br />'
);
//使用trim后
</script>
|
测试的结果如下:
length:11 ltrim length:10 rtrim length:10 trim length:9 限制文本框只能输入数字和小数点等等 。
来源:文本框输入限制的问题????
只能输入数字和小数点 。
var reg = /^\d*\.?\d{0,2}$/ 开头有若干个数字,中间有0个或者一个小数点,结尾有0到2个数字.
只能输入小写的英文字母和小数点,和冒号,正反斜杠(:./\) 。
var reg = /[a-z\.\/\\:]+/; a-z包括了小写的英文字母,\.是小数点,\/和\\分别是左右反斜线,最后是冒号。整个组成一个字符集和代码任一均可,最后在加上+,1或者多个.
替换小数点前内容为指定内容 。
来源:求一正则表达式! 。
请问 怎么把这个字符串的小数点前面的字符替换为我自定义的字符串啊?
例如:infomarket.php?id=197 替换为 test.php?id=197 。
应该可以把第一个点“.”之前的所有单词字符替换为test就可以了。我写的正则如下:
1
2
3
4
5
6
7
|
<script type=
"text/javascript"
>
var
str =
"infomarket.php?id=197"
;
var
reg = /^\w*/ig;
//匹配字符串开头的任意个单词字符
str = str.replace(reg,
'test'
);
document.write(str);
</script>
|
原帖的有点复杂,没太看明白.
只匹配中文的正则表达式 。
来源:关于上传的时候,只能选择中文名称的图片(是否可以用toASCII方法呢?) 。
前两天看的《JavaScript开发王》里恰好有中文的unicode范围,正则如下:
/[\u4E00-\u9FA5\uf900-\ufa2d]/ 写了一个简单的测试,会把所有的中文替换成“哦”.
1
2
3
4
5
6
|
<script type=
"text/javascript"
>
var
str =
"有中文?and English."
;
var
reg = /[\u4E00-\u9FA5\uf900-\ufa2d]/ig;
str = str.replace(reg,
'哦'
);
document.write(str);
</script>
|
返回字符串的中文字符个数 。
来源:有没返回中文字符字节的函数! 。
一般的字符长度对中文和英文都是不分别的 如JS里的length,那么如何返回字符串中中文字符的个数呢?guoshuang老师在原帖中给出了解决方案,我又没看懂…… 。
不过我自己也想到了一个办法:先去掉非中文字符,再返回length属性。函数以及测试代码如下:
1
2
3
4
5
6
7
8
9
10
11
|
<script type=
"text/javascript"
>
function
cLength(str){
var
reg = /[^\u4E00-\u9FA5\uf900-\ufa2d]/g;
//匹配非中文的正则表达式
var
temp = str.replace(reg,
''
);
return
temp.length;
}
var
str =
"中文123"
;
document.write(str.length+
'<br />'
);
document.write(cLength(str));
</script>
|
结果:
5 。
2 。
中文两个,数字三个,正确.
下面的测试也正确.
1
2
3
|
var
str =
"中文123tets@#!#%$#[][{}"
;
document.write(str.length+
'<br />'
);
document.write(cLength(str));
|
正则表达式取得匹配IP地址前三段 。
来源:如何用正则取IP前3段 。
192.168.118.101,192.168.118.72, 192.168.118.1都替换成:192.168.118 。
只要匹配掉最后一段并且替换为空字符串就行了,正则如下:
/\.\d{1,3}$/ 匹配结尾的.n,.nn或者.nnn.
测试代码如下:
1
2
3
4
5
6
7
8
9
10
|
function
replaceReg(reg,str){
return
str.replace(reg,
''
)
}
var
reg = /\.\d{1,3}$/;
var
str =
'192.168.118.101'
;
var
str2 =
'192.168.118.72'
;
var
str3 =
'192.168.118.1'
;
document.write(replaceReg(reg,str)+
'<br />'
);
document.write(replaceReg(reg,str2)+
'<br />'
);
document.write(replaceReg(reg,str3)+
'<br />'
);
|
相似的有,这个帖子里有一个验证IP地址的方法:求检验MAC地址的正则表达例子 。
匹配<ul>与<ul>之间的内容 来源:请教个正则的小问题吧 <ul>safsf<ul>safsf</ul><ul>safsf</ul></ul> 。
用正则可以得到 <ul>起到下个<ul> 之间的内容.
正则如下:
/<ul>[\s\S]+?<ul>/i 首先匹配两侧的ul标签,中间的[\s\S]+?可以匹配一个或者多个任意字符,一定要非贪婪,否则会匹配<ul>safsf<ul>safsf</ul><ul>.
用正则表达式获得文件名 。
来源:C:\006.jpg 。
c:\images\tupian\006.jpg 。
可能是直接在盘符根目录下,也可能在好几层目录下,要求替换到只剩文件名.
xlez的正则如下:
/[^\\\/]*[\\\/]+/g 首先匹配非左右斜线字符0或多个,然后是左右斜线一个或者多个。形如“xxx/”或者“xxx\”或者“/”或者“\” 。
函数以及测试代码:
1
2
3
4
5
6
7
8
9
10
11
12
|
<script type=
"text/javascript"
>
function
getFileName(str){
var
reg = /[^\\\/]*[\\\/]+/g;
//xxx\或者是xxx/
str = str.replace(reg,
''
);
return
str;
}
var
str =
"c:\\images\\tupian\\006.jpg"
;
document.write(getFileName(str)+
'<br />'
);
var
str2 =
"c:/images/tupian/test2.jpg"
;
document.write(getFileName(str2));
</script>
|
注意,\需要转义.
绝对路径变相对路径 。
来源:讨论一个正则 。
将<IMG height="120" width="800" src="http://23.123.22.12/image/somepic.gif">转换为:<IMG height="120" width="800" src="/image/somepic.gif">.
其中网址可能改变,例如http://localhost等等.
cloudchen的正则:
/http:\/\/[^\/]+/ 首先是http://,然后[^\/]+找过1个或者多个非/字符,因为遇到第一个/表示已经到目录了,停止匹配.
测试代码如下:
1
2
3
4
5
6
|
<script type=
"text/javascript"
>
var
str =
'<IMG height="120" width="800" \src="http://23.123.22.12/image/somepic.gif">'
;
var
reg = /http:\/\/[^\/]+/;
str = str.replace(reg,
""
);
alert(str)
</script>
|
用户名正则 。
来源:求正则,急急呀!! 。
用于用户名注册,,用户名只 能用 中文、英文、数字、下划线、4-16个字符.
hansir和解决方案弄成正则:
/^[\u4E00-\u9FA5\uf900-\ufa2d\w]{4,16}$/ 中文字符或者单词字符,4到16个。实现4到16结成到正则里的关键就是开始^和结束$,这就等于整个字符串只能有这些匹配的内容,不能有多余的.
函数和测试代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<script type=
"text/javascript"
>
function
isEmail(str){
var
reg = /^[\u4E00-\u9FA5\uf900-\ufa2d\w]{4,16}$/;
return
reg.test(str);
}
var
str =
'超级无敌用户名regExp'
;
var
str2 =
'捣乱的@'
;
var
str3 =
'太短'
var
str4 =
'太长longlonglonglonglonglonglonglong'
document.write(isEmail(str)+
'<br />'
);
document.write(isEmail(str2)+
'<br />'
);
document.write(isEmail(str3)+
'<br />'
);
document.write(isEmail(str4)+
'<br />'
);
</script>
|
匹配英文地址 。
来源:-求助- 正则问题 。
规则如下
包含 "点", "字母","空格","逗号","数字",但开头和结尾不能是除字母外任何字符.
[\.a-zA-Z\s,0-9]这个字符集就实现了字母,空格,逗号和数字。最终正则如下:
/^[a-zA-Z][\.a-zA-Z\s,0-9]*?[a-zA-Z]+$/ 开头必须有字母,结束也必须是一个以上字母。测试代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
|
<script type=
"text/javascript"
>
function
testReg(reg,str){
return
reg.test(str);
}
var
reg = /^[a-zA-Z][\.a-zA-Z\s,0-9]*?[a-zA-Z]+$/;
var
str =
'No.8,ChangAn Street,BeiJing,China'
;
var
str2 =
'8.No,ChangAn Street,BeiJing,China'
;
var
str3 =
'No.8,ChangAn Street,BeiJing,China88'
;
document.write(testReg(reg,str)+
'<br />'
)
document.write(testReg(reg,str2)+
'<br />'
)
document.write(testReg(reg,str3)+
'<br />'
)
</script>
|
正则匹配价格 。
来源:为什么这个正则不起作用啊?急啊?
价格的格式应该如下:
开头数字若干位,可能有一个小数点,小数点后面可以有两位数字。hansir给出的对应正则如下:
/^(\d*\.\d{0,2}|\d+).*$/ hansir给出的测试代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
<!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
>
<html xmlns=
"http://www.w3.org/1999/xhtml"
>
<head>
<meta http-equiv=
"Content-Type"
content=
"text/html; charset=gb2312"
/>
<title>无标题文档</title>
<script type=
"text/javascript"
>
function
checkPrice(me){
if
(!(/^(?:\d+|\d+\.\d{0,2})$/.test(me.value))){
me.value = me.value.replace(/^(\d*\.\d{0,2}|\d+).*$/,
'$1'
);
}
}
</script>
</head>
<body>
<input type=
"text"
onkeyup=
"checkPrice(this);"
/>
</body>
</html>
|
身份证号码的匹配 。
来源:关于正则的,大家帮帮忙,急,在线等 。
身份证号码可以是15位或者是18位,其中最后一位可以是X。其它全是数字,正则如下:
/^(\d{14}|\d{17})(\d|[xX])$/ 开头是14位或者17位数字,结尾可以是数字或者是x或者是X.
测试代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<script type=
"text/javascript"
>
function
testReg(reg,str){
return
reg.test(str);
}
var
reg = /^(\d{14}|\d{17})(\d|[xX])$/;
var
str =
'123456789012345'
;
//15位
var
str2 =
'123456789012345678'
;
//18位
var
str3 =
'12345678901234567X'
;
//最后一位是X
var
str4 =
'1234'
;
//位数不对
document.write(testReg(reg,str)+
'<br />'
);
document.write(testReg(reg,str2)+
'<br />'
);
document.write(testReg(reg,str3)+
'<br />'
);
document.write(testReg(reg,str4)+
'<br />'
);
</script>
|
要求文本有指定行数 。
来源:[求助]求一句正则表达式的写法 。
匹配至少两行的字符串,每行都为非空字符.
只要匹配到[\n\r]就表示有换行了,再保证换行的两段都不是空字符就可以了。正则如下:
/\S+?[\n\r]\S+?/i 这个正则的应用应该是用在textarea里,如果是如下要求:可以支持所有字符,中间可带空格,可以包括英文、数字、中文、标点 。
这样的话,只要针对空格再改一下就行了。(按照非空的要求,上面有不能匹配“字符+空格+换行+字符”的字符串)。修改如下:
/\S+?\s*?[\n\r]\s*?\S+?/i 单词首字母大写 来源:求个正则,处理英文单词或词组的 。
每单词首字大写,其他小写。如blue idea转换为Blue Idea,BLUE IDEA也转换为Blue Idea 。
cloeft的正则:
/\b(\w)|\s(\w)/g 所谓“首字母”包括两种情况:第一种是边界(开头)的单词字符,一种是空格之后的新单词的第一个字母。测试代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
<script type=
"text/javascript"
>
function
replaceReg(reg,str){
str = str.toLowerCase();
return
str.replace(reg,
function
(m){
return
m.toUpperCase()})
}
var
reg = /\b(\w)|\s(\w)/g;
var
str =
'blue idea'
;
var
str2 =
'BLUE IDEA'
;
var
str3 =
'Test \n str is no good!'
;
var
str4 =
'final test'
;
document.write(replaceReg(reg,str)+
'<br />'
);
document.write(replaceReg(reg,str2)+
'<br />'
);
document.write(replaceReg(reg,str3)+
'<br />'
);
document.write(replaceReg(reg,str4)+
'<br />'
);
</script>
|
正则验证日期格式 。
来源:yyyy-mm-dd的正则怎样写啊?
yyyy-mm-dd格式 。
正则如下:
/^\d{4}-\d{1,2}-\d{1,2}$/ 4位数字,横线,1或者2位数字,再横线,最后又是1或者2位数字.
测试代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<script type=
"text/javascript"
>
function
testReg(reg,str){
return
reg.test(str);
}
var
reg = /^\d{4}-\d{1,2}-\d{1,2}$/;
var
str =
'2008-8-8'
;
var
str2 =
'2008-08-08'
;
var
str3 =
'08-08-2008'
;
var
str4 =
'2008 08 08'
;
document.write(testReg(reg,str)+
'<br />'
);
document.write(testReg(reg,str2)+
'<br />'
);
document.write(testReg(reg,str3)+
'<br />'
);
document.write(testReg(reg,str4)+
'<br />'
);
</script>
|
第二种格式:来源:求一正则表达式 。
yyyy-mm-dd 。
或 。
yyyy/mm/dd 。
用“或”简单地修改一下就行了.
/^\d{4}(-|\/)\d{1,2}(-|\/)\d{1,2}$/ 去掉文件的后缀名 。
来源:求一个正则 。
www.abc.com/dc/fda.asp变为www.abc.com/dc/fda 。
如果文件后缀已知的话这个问题就非常简单了,正则如下:
/\.asp$/ 匹配最后的.asp而已,测试代码如下:
1
2
3
4
5
6
7
8
|
<script type=
"text/javascript"
>
function
delAspExtension(str){
var
reg = /\.asp$/;
return
str.replace(reg,
''
);
}
var
str =
'www.abc.com/dc/fda.asp'
;
document.write(delAspExtension(str)+
'<br />'
);
</script>
|
如果文件名未知的话就用这个正则:/\.\w+$/,测试代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
|
<script type=
"text/javascript"
>
function
delExtension(str){
var
reg = /\.\w+$/;
return
str.replace(reg,
''
);
}
var
str =
'example.com/dc/fda.asp'
;
document.write(delExtension(str)+
'<br />'
);
var
str2 =
'test/regular/fda.do'
;
document.write(delExtension(str2)+
'<br />'
);
var
str3 =
'example.com/dc/fda.strange_extension'
;
document.write(delExtension(str3)+
'<br />'
);
</script>
|
验证邮箱的正则表达式 。
来源:找javascript写的表单检查代码! 。
fuchangxi的正则:
/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(\.[a-zA-Z0-9_-])+/ 开始必须是一个或者多个单词字符或者是-,加上@,然后又是一个或者多个单词字符或者是-。然后是点“.”和单词字符和-的组合,可以有一个或者多个组合.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
<script type=
"text/javascript"
>
function
isEmail(str){
var
reg = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(\.[a-zA-Z0-9_-])+/;
return
reg.test(str);
}
var
str =
'test@hotmail.com'
;
document.write(isEmail(str)+
'<br />'
);
var
str2 =
'test@sima.vip.com'
;
document.write(isEmail(str2)+
'<br />'
);
var
str3 =
'te-st@qq.com.cn'
;
document.write(isEmail(str3)+
'<br />'
);
var
str4 =
'te_st@sima.vip.com'
;
document.write(isEmail(str4)+
'<br />'
);
var
str5 =
'te.._st@sima.vip.com'
;
document.write(isEmail(str5)+
'<br />'
);
</script>
|
我不太了解邮箱的具体规则。感觉这个正则比较简单,EMAIL校验 正则 讨论 求解里有比较详细的邮箱正则讨论.
匹配源代码中的链接 。
来源:正则 。
能够匹配HTML代码中链接的正则.
原帖正则:
/<a href=".+?">.+?<\/a>/g 感觉有点严格,首先要<a href="".+?">有,而且href属性可以是一个或者多个除换行外任意字符(非贪婪)。后面是.+?<\/a>,一个或者多个除换行外任意字符(非贪婪),再加上结束标签.
有个问题,如果a的起始标签最后有空格,或者除了href还有其它属性的话,上面的正则就不能匹配这个链接了.
例如:
<a href="asdfs" >……多了个空格.
<a id="xx" href=""asdfs">……前面有属性.
…… 。
重写正则:
/<a\s(\s*\w*?=".+?")*(\s*href=".+?")(\s*\w*?=".+?")*\s*>[\s\S]*?<\/a>/ 思路如下:首先要有<a和一个空格。/<a\s/ 。
第一个(\s*\w*?=".+?")* 。
可以匹配一个属性,属性前面可能有或者没有多余的空格,用\s*匹配;属性名肯定是单词字符,用\w*?匹配;=".+?"就是匹配属性值了非换行字符若干个;整个括号外面加个*表示可能有任意多个属性.
(\s*href=".+?") 。
匹配href,它也是一个属性,所以只要把上面子正则表达式中的\w修改为href=就行了.
(\s*\w*?=".+?")*重复第一个子正则表达式,再次接受任意个属性.
\s*>,属性最后再加上若干个空格和>.
[\s\S]*?,链接的文字,可能有任何字符组成,若干个,非贪婪.
<\/a>最后是结束标签.
补充:属性名和=之间,以及=和属性值之间也可能有空格。所以要再加上几个\s*.
最后的实例代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<script type=
"text/javascript"
>
function
findLinks(str){
var
reg = /<a\s(\s*\w*?\s*=\s*
".+?"
)*(\s*href\s*=\s*
".+?"
)(\s*\w*?\s*=\s*
".+?"
)
*\s*>[\s\S]*?<\/a>/g;
var
arr = str.match(reg);
for
(
var
i=0;i<arr.length;i++){
//alert(arr[i]);
document.write(
'link:'
+arr[i]+
'<br />'
);
}
}
var
str =
'<p>测试链接:<a id = "test" href="http://bbs.blueidea.com" id="codetool">
会把所有的链接在页面直接显示出来。注意, 。 本帖遗留问题:如何执行从右到左的匹配。貌似JS或者VBS没有提供这个功能2、JS或者VBS不支持 后行断言。。用什么方法实现这个功能. 匹配链接的文字 来源:求一正则? 代码:<a href="#>这里要保存</a>,只保存链接的文本内容,标签信息删掉. 前面写过一个匹配链接的正则: /<a\s(\s*\w*?=".+?")*(\s*href=".+?")(\s*\w*?=".+?")*\s*>[\s\S]*?<\/a>/ 不过我们需要捕获的是文字内容,所以需要做一定的修改。第一步就是在所有的括号内都加上?:表示不捕获。第二步就是再多加一个括号放在[\s\S]*?两侧,这样就可以捕获到链接的文字内容了。最后正则如下:
测试代码如下:
|
最后此篇关于JavaScript中常用的正则表达式日常整理(全)的文章就讲到这里了,如果你想了解更多关于JavaScript中常用的正则表达式日常整理(全)的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
Apache服务器全局配置之服务器标识配置篇 服务器标识相关指令: ServerName ServerAdmin ServerSignature ServerTokens UseCanonical
//校验是否全由数字组成 ? 1
具体内容如下: 1 os.system 例如 ipython中运行如下命令,返回运行状态status os.system('cat /etc/passwdqc.conf') min=disab
基本操作 查看数据库 ? 1
Xcode使用教程详细讲解是本文要介绍的内容,Xcode是一个款强大的IDE开发环境,就像你在写Windows程序时需要VS2005一样 需要要Xcode为你写Mac程序提供环境。因此,如果你要成为
就如今天遇到随即函数rand();脑海中想到用它做点啥好呢,最后想起了验证码,数字验证码,字母验证码,中文验证码,可是自己不会呀,咋办呢,上网搜,看别人的代码,开不懂,看视频,听老师讲,将其中所遇到
pcre-7.8.tar.gz 正则表达式下载地址:ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/
IDEA常用设置(提高开发效率) 本人也是IDEA编译器的忠实用户了,但是有时出于各种原因,比如更换设备等等,IDEA总是需要重新安装配置。这就让我比较苦恼,因为总是记不全自己之前都修改了
? 1 2
1、 操作环境搭建 系统:Windows7 旗舰版 64位 PHP环境:wampserver2.2e-php5.4.3-httpd2.2.22-mysql5.5.24 32
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 去年关闭。 Improve th
我已经为我在 Adobe Fireworks Cs5 中构建的页面生成了 css,我想知道如何为我的标题和其他 div 设置完整宽度。我将显示标题部分的 css 代码。 @charset "utf
您好,我希望表单宽度为 100%。我希望文本框几乎延伸整个页面的宽度,并在文本框的右侧直接放置小的“GO”按钮,所有按钮都在同一行(或 block )上。 现在我的文本框只有其中文本的宽度(“在此处输
我没有设法将全宽页脚粘贴到网页底部。当页脚上方的主要内容低于一定高度时,页脚下方有一个空白区域。我尝试使用各种解决方案,例如以下 css 代码: html,body { margin:0; padd
我想要一个全宽的表格。当我给 position:fixed; 它变成全宽但可滚动不起作用。 简而言之,我需要一个与浏览器主体没有任何边距的表格。 body { font-family: "Helv
我注意到很多大型网站(如 Google 和 Facebook)在查看页面源代码时 99% 的源代码都是 JavaScript。 有人知道这种方法相对于常规 HTML+JavaScript 页面的优势吗
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 8 年前。 Improve this q
由于某种原因,我网站上的图片不再是全宽的。 据我所见,所有内容都设置为 100% 宽度。 http://cargocollective.com/btatest 我是不是什么地方都没有? 最佳答案 我认
我正在创建一个菜单并尝试使用 CSS 制作全宽菜单。但是,我不确定菜单项将如何出现在菜单中。 这是问题的截图: 问题出在我得到的“GAP”中。 如果我有固定数量的元素,我知道我可以使用这个逻辑: ul
这个问题在这里已经有了答案: Puzzle: Find largest rectangle (maximal rectangle problem) (6 个答案) 关闭 9 年前。 给定一个二元矩阵
我是一名优秀的程序员,十分优秀!