/\D/g

onKeyUp=”this.value=this.value.replace(/\D/g,”);”
红色的是什么意识

/g是什么意思


/g是全局匹配


js里可以使用perl风格的表达式
/表达式内容/参数
如/\D/g

g :全局匹配


\D:类似[^0-9] 非数字
/g:全局

把所有非数字的替换成空

/一定要加上的吗

var reg = /expression/img ;

前后的两个“/”是必须的,就这样的语法规则,就像声明字符串
String test = “only a test”;
前后的“””必须要有一样,语法规则,没什么道理可讲

img 是模式,为可选参数
i 忽略大小写
m 多行模式

g 全局模式

http://bbs.youkuaiyun.com/topics/340198344
http://msdn.microsoft.com/zh-cn/library/ae5bf541(v=vs.90).aspx


整数或者小数:^[0-9]+.{0,1}[0-9]{0,2} [09] ”。
只能输入n位的数字:”^\d{n} n\dn, ”。
只能输入m~n位的数字:。”^\d{m,n} (0|[19][09]) ”。
只能输入有两位小数的正实数:”^[0-9]+(.[0-9]{2})? 1 3[09]+(.[09]1,3)? ”。
只能输入非零的正整数:”^+?[1-9][0-9]* [19][]09
只能输入长度为3的字符:”^.{3} 26[AZaz]+ ”。
只能输入由26个大写英文字母组成的字符串:”^[A-Z]+ 26[az]+ ”。
只能输入由数字和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-./?%&=]*)? ((\d3,4)|\d3.4)?\d7,8 ”正确格式为:”XXX-XXXXXXX”、”XXXX-XXXXXXXX”、”XXX-XXXXXXX”、”XXX-XXXXXXXX”、”XXXXXXX”和”XXXXXXXX”。
验证身份证号(15位或18位数字):”^\d{15}|\d{18} 12(0?[19]|1[02]) ”正确格式为:”01”~”09”和”1”~”12”。
验证一个月的31天:”^((0?[1-9])|((1|2)[0-9])|30|31)$”正确格式为;”01”~”09”和”1”~”31”。
匹配中文字符的正则表达式: [\u4e00-\u9fa5]

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

应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
String.prototype.len=function(){return this.replace(/[^\x00-\xff]/g,”aa”).length;}

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

匹配html标签的正则表达式:<(.)>(.)<\/(.)>|<(.)\/>

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

应用:JavaScript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现,如下:

String.prototype.trim = function()
{
return this.replace(/(^\s*)|(\s*$)/g, “”);
}

利用正则表达式分解和转换IP地址:

下面是利用正则表达式匹配IP地址,并将IP地址转换成对应数值的Javascript程序:

function IP2V(ip)
{
re=/(\d+).(\d+).(\d+).(\d+)/g //匹配IP地址的正则表达式
if(re.test(ip))
{
return RegExp. 1Math.pow(255,3))+RegExp. 2*Math.pow(255,2))+RegExp. 3255+RegExp. 4*1
}
else
{
throw new Error(“Not a valid IP address!”)
}
}

不过上面的程序如果不用正则表达式,而直接用split函数来分解可能更简单,程序如下:

var ip=”10.100.20.168”
ip=ip.split(“.”)
alert(“IP值是:”+(ip[0]*255*255*255+ip[1]*255*255+ip[2]*255+ip[3]*1))

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

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

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

用正则表达式限制只能输入中文:οnkeyup=”value=value.replace(/[^\u4E00-\u9FA5]/g,”)” onbeforepaste=”clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^\u4E00-\u9FA5]/g,”))”

用正则表达式限制只能输入全角字符: οnkeyup=”value=value.replace(/[^\uFF00-\uFFFF]/g,”)” onbeforepaste=”clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^\uFF00-\uFFFF]/g,”))”

用正则表达式限制只能输入数字:οnkeyup=”value=value.replace(/[^\d]/g,”) “onbeforepaste=”clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^\d]/g,”))”

用正则表达式限制只能输入数字和英文:οnkeyup=”value=value.replace(/[\W]/g,”) “onbeforepaste=”clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^\d]/g,”))”

if (document.layers)//触发键盘事件 document.captureEvents(Event.KEYPRESS) function xz(thsv,nob){ if(nob=="2"){ window.clipboardData.setData("text","") alert("避免非法字符输入,请勿复制字符"); return false; } if (event.keyCode!=8 && event.keyCode!=16 && event.keyCode!=37 && event.keyCode!=38 && event.keyCode!=39 && event.keyCode!=40){ thsvv=thsv.value;//输入的值 thsvs=thsvv.substring(thsvv.length-1);//输入的最后一个字符 //thsvss=thsvv.substring(0,thsvv.length-1);//去掉最后一个错误字符 if (!thsvs.replace(/[^\u4E00-\u9FA5\w]/g,'') || event.keyCode==189){//正则除去符号和下划线 key thsv.value='请勿输入非法符号 ['+thsvs+']'; alert('请勿输入非法符号 ['+thsvs+']'); thsv.value=""; return false; } } }

允许数字字母和汉字

<think>嗯,用户问的是如何在gvim中使用命令删除匹配xxx的行,具体是:g/xxx/d的用法。首先,我需要回忆一下vim的相关命令。根据引用里的内容,特别是引用[2]和引用[4],用户之前提供的资料里提到过删除包含特定关键字的行可以用:g/text/d,删除不包含的用:v/#/d或者%g!/#/d。还有关于range的规定,比如%表示所有行,m,n表示从m到n行。 用户的问题应该直接对应到:g/xxx/d这个命令。这里的xxx是用户想要匹配的模式。记得在vim中,:g/pattern/command会执行command在处理所有匹配pattern的行。所以删除的话就是用d命令。需要确认命令的语法是否正确,是否有其他参数需要注意,比如范围。根据引用[4],如果不指定range,默认是全部行,但:g本身已经隐含了全局搜索,所以可能不需要额外指定范围。 另外,用户可能会遇到的常见问题包括正则表达式中的特殊字符需要转义,比如如果xxx里有.或者*,需要转义成\.或\*。比如要删除包含"file.txt"的行,应该写成:g/file\.txt/d。这点在引用[3]里提到过,要注意位置匹配和特殊字符的问题。 可能还需要解释一下:g的相反命令是:v,也就是:g!/xxx/d等同于:v/xxx/d,用来删除不匹配的行。这在引用[2]里有例子。用户如果有这方面的需求,也需要一并说明。 另外,用户可能想知道如何删除精确匹配的词,比如使用\<和\>来限定词首词尾。比如删除有单词"word"的行,可以用:g/\<word\>/d,这在引用[3]里提到过词首词尾的匹配符。 还有,可能需要提到删除空行的情况,比如:g/^$/d,这在引用[2]里也有例子。用户如果问的是删除空行,可以用这个命令,但当前问题主要是关于匹配任意xxx,所以重点在:g/xxx/d。 总结一下,回答应该包括基本命令的用法,注意事项如特殊字符转义,相关的例子,以及扩展命令如:v的使用。同时,引用相关的引用资料,比如引用[2]和引用[3]、[4]来支持解释的正确性。</think>在gvim中删除匹配特定模式的行可通过`:g/模式/d`命令实现,以下是具体用法和注意事项: ### 一、基础命令格式 ``` :g/xxx/d ``` - **效果**:删除所有包含`xxx`模式的行 - **原理**:`:g`(global命令)遍历所有行,对匹配`xxx`的行执行`d`(delete)操作[^2][^4] ### 二、特殊字符处理(正则表达式) 1. **匹配行首/行尾**: ```vim :g/^xxx/d # 删除以xxx开头的行 :g/xxx$/d # 删除以xxx结尾的行 ``` 2. **精确单词匹配**: ```vim :g/\<xxx\>/d # 删除包含完整单词xxx的行(不匹配subxxx或xxxsub)[^3] ``` 3. **转义特殊符号**: ```vim :g/file\.txt/d # 删除包含"file.txt"的行(需转义`.`) ``` ### 三、反向操作 ```vim :v/xxx/d # 删除所有不包含xxx的行(等同于:g!/xxx/d)[^2] ``` ### 四、典型应用场景 1. 删除注释行: ```vim :g/^#/d # 删除所有以#开头的行(如Shell/Python注释) ``` 2. 删除空行: ```vim :g/^$/d # 删除所有空行[^2] ``` 3. 删除含日期的行: ```vim :g/2023-\d\{4\}/d # 删除包含"2023-XXXX"格式日期的行 ``` ### 五、注意事项 1. 操作前建议先执行`:set nu`显示行号以便核对 2. 正则表达式默认区分大小写,添加`\c`可忽略大小写(如`:g/\cXXX/d`) 3. 支持组合其他命令(如先复制再删除): ```vim :g/xxx/yank A | d # 将匹配行复制到寄存器A后再删除 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值