正则表达式笔记3

敏感词过滤

//| : 或的意思

//replace : 第二个参数:可以是字符串,也可以是一个回调函数

//菲称仁爱礁附近17艘中国船均在菲军监视之下

window.onload = function(){
		var aT = document.getElementsByTagName(‘textarea‘);
		var oInput = document.getElementById(‘input1‘);

		re = /菲称|中国|菲军/g;

		oInput.onclick = function(){

			// 方法一
			// aT[1].value = aT[0].value.replace(re,‘*‘);

			// 方法二
			aT[1].value = aT[0].value.replace(re,function(str){

				//函数的第一个参数:就是匹配成功的字符
				console.log(str);

				var result = ‘‘;

				for (var i = 0; i < str.length; i++) {
					result += ‘*‘;
				};
				return result;
			});
		};

	}

  

替换前<br />
	<textarea>
	</textarea><br />
	替换后<br />
	<textarea>
	</textarea><br />
	<input type="button" value="确定" id="input1" />

匹配子项

//匹配子项 : 小括号 ()  (还有另外一个意思,分组操作)

//1+1*2
//(1+1)*2

//把正则的整体叫做(母亲)
//然后把左边第一个小括号里面的正则,叫做这个第一个子项(母亲的第一个孩子)
//第二个小括号就是第二个孩子

var str = ‘2017-5-25‘;

var re = /(\d+)(-)/g;

str = str.replace(re,function($0,$1,$2){
	//第一个参数:$0(母亲),第二个参数 : $1(第一个孩子)
	//,第二个参数 : $1(第二个孩子)

	console.log( $1 );

	return $1 + ‘.‘;

	return $0.substring(0,$0.length-1) + ‘.‘;

});

console.log( str );   //2017.5.25

var str2 = ‘abc‘;

var re = /(a)(b)(c)/;

//[abc,a,b,c](当match不加g的时候才可以获取到子项的集合)
console.log(str2.match(re));

  

字符类:

//字符类 : 一组相似的元素   [] 中括号的整体代表其中一个字符

		var str = ‘abdc‘;

		var re =/a[bde]c/;

		console.log(re.test(str));	//false

		//排除 : ^ 如果^写在[]里面的话,就代表排除的意思

		var str2 = ‘abc‘;

		var re = /a[^bdef]c/;

		console.log(re.test(str2));	//false

		var str3 = ‘abc‘;

		var re = /a[a-z0-9A-Z]c/;	

		console.log( re.test(str3) );	//true

  

转义字符:

//.  :  任意字符
		//\. : 真正的点

		var str = ‘a.c‘;

		var re = /a\.c/;

		console.log(re.test(str));	//true

		var str2 = ‘abcdef‘;

		var re2 = /a.cd/;

		console.log(re2.test(str2));	//true

		//\b : 独立的部分  匹配单词边界,不匹配任何字符 ( 起始,结束,空格 )
		//\B : 非独立的部分

		var str3 = ‘onetwo‘;
		var str4 = ‘one two‘;

		var re3 = /one\b/;

		console.log( re3.test(str3) );	//false
		console.log( re3.test(str4) );	//true

		/*
			\b说明:
			我要从一堆原始数据中查找55这个数字,包括三种情况:
			假设原始数据是: 123512,a55bcd,55abc,abc55,1235bs,asdfc,55,
			1.要求:只有55,前后都不能有其他字符,比如a55bcd,55abc,abc55都是不行的
			  这种情况下,用\b55\b,\b就相当于一个停止分界线,告诉电脑55的前面和后面都不允许带字符
			2.要求:以55开头,后面允许带字符比如55abc,55,但是a55bcd是不允许的
			  这种情况下,用\b55,这里只有55前面有停止分界线\b,告诉电脑前面不允许带字符,后面没有停止分界线,后面可以带字符
			3.要求:以55结尾,前面允许带字符,后面不允许.比如abc55是允许的,但是a55bcd是不允许的
			  这种情况下,用55\b,这里是有55后面有停止分界线,告诉电脑后面不允许带字符,前面没有停止分界线,是允许   带字符的
		*/
时间: 2024-08-02 09:27:20

正则表达式笔记3的相关文章

c# 正则表达式笔记

c# 正则表达式笔记 正则所需要的命名空间是 using System.Text.RegularExpressions 它包含了8个类,用得最多是的Regex; Regex不仅可以用来创建正则表达式,而且提供了许多有用的方法. 创建一个Regex对象 new Regex(string pattern) new Regex(string pattern,RegexOptions options) 第一个参数是个字符串   第二个参数正则配置的选项 有以下一些选项 IgnoreCase       

javascript正则表达式笔记(转载)

在javascript里面的定义 1.通过RegExp构造函数定义一个正则表达式.第一个参数为正则表达式以字符串传入,第二个参数为修饰符也以字符串传入. 例:var caps = new RegExp("[A-Z]", "g"); 2.直接定义一个正则表达式直接量,表达式右正斜杠符号"/"分隔,后直接跟修饰符.(推荐用这种) 例:var caps = /[A-Z]/g; javascript正则表达式常用的字符 字符 描述 例子 [exp] 对于

整理的正则表达式笔记

最近在学python中的re模块 自己打印了一份正则表达式资料,看了一中午的笔记,拿出来和大家分享. 纯文本正则可匹配 i标志 强行不区分大小写 c.t 匹配 cat cbt.... .匹配任意单个字符 ..任意两个字符 [ab]只匹配ab [a-zA-Z0-9] 取色#[a-fA-F0-9][a-fA-F0-9][a-fA-F0-9][a-fA-F0-9][a-fA-F0-9][a-fA-F0-9] 改良取色#[a-fA-F0-9]{6} [^0-9]非匹配 [0-9]反斜线转义匹配方括号 \

正则表达式笔记

正则表达式到底是什么东西?在编写处理字符串的程序或网页时,经常会有查找符合某些复杂规则的字符串的需要.正则表达式就是用于描述这些规则的工具.换句话说,正则表达式就是记录文本规则的代码.常用元字符 代码 说明 . 匹配除换行符以外的任意字符 \w 匹配字母或数字或下划线或汉字 \s 匹配任意的空白符 \d 匹配数字 \b 匹配单词的开始或结束 ^ 匹配字符串的开始 $ 匹配字符串的结束 常用限定符 代码/语法 说明 * 重复零次或更多次 + 重复一次或更多次 ? 重复零次或一次 {n} 重复n次

javascript正则表达式笔记

g 代表全局匹配m 代表可以进行多行匹配i 代表不区分大小写匹配^ 匹配输入字符串的开始位置$ 匹配输入字符串的结束位置* 匹配前面的子表达式零次或多次. 等价于{0,}+ 匹配前面的子表达式一次或多次. 等价于{1,}? 匹配前面的子表达式零次或一次. 等价于{0,1} , 当该字符跟在任何一个其他限制符(*, +, ?, {n}, {n,}, {n,m}) 后面时,匹配模式是非贪婪的.非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串.例如,对于字符串 "

学习正则表达式笔记(二)

正则匹配的各种模式 1.择一匹配(|) 择一匹配用管道符号(|),也就是竖线表示.代表可以从多个模式中选择一个,可用于分割正则表达式.例如: ABC | abc 表示即可以匹配 ABC,又可以匹配 abc. 2.匹配任意单个字符 点号(.)可以匹配除换行符 \n 以外的任意字符,无论是空格,字母,数字,可打印字符.不可打印字符,还是一个符号,使用点号都能够匹配它们. 在Python中,如果使用模块属性re.S 也就是 re.DOTALL,那么换行符 \n 也可以匹配了. 3.从字符串起始或者结尾

python 正则表达式 笔记

{jpg,gif} jpg或者gif两个单词 [jpg|gif] 凡是由jpgif这几个字母组成的字符 [001-010] 数字001-010之间10个数字 $ curl -O http://cgi2.tky.3web.ne.jp/~{zzh,nick}/[001-201].JPG 这样产生的下载,就是 ~zzh/001.JPG ~zzh/002.JPG ... ~zzh/201.JPG ~nick/001.JPG ~nick/002.JPG ... ~nick/201.JPG 调用正则表达式中

学习正则表达式笔记

1.正则表达式简介 正则表达式为高级的文本模式匹配,抽取,与和或形式的搜索和替换功能提供了基础.也就是说正则表达式(RegEx)能匹配到多个字符,你就可以很容易的操作这些匹配到的字符,只要你运用正确的字符和特殊符号. Python中通过导入 re 模块来支持正则表达式. 2.常见的正则表达式符号和特殊字符 2.1符号 符号表示法 描述 示例 literal 匹配文本字符串的字面值 literal,即匹配原始字符 foo re1|re2 匹配正则表达式 re1 或者 re2,中间的 | 相当于或,

java正则表达式笔记

1.正则表达式的概述和简单使用 A:正则表达式 是指一个用来描述或者匹配一系列符合某个语法规则的字符串的单个字符串.其实就是一种规则.有自己特殊的应用. 作用:比如注册邮箱,邮箱有用户名和密码,一般会对其限制长度,这个限制长度的事情就是正则表达式做的 作用:专门用于操作字符串                特点:用一些特定的符号来表示一些代码的操作.这样就简化书写. 所以学正则表达式,就是学习一些特殊符号的使用. 好处:可以简化对字符串的操作 弊端:符号定义越多,正则越长,阅读性越差 B:案例演

正则表达式笔记 sed工具

[:alnum:] 代表英文大小写字符及数字,即0-9 A-Z a-z [:alpha:] 代表任何英文大小写字符,即A-Z a-z [:blank:] 代表空格键与TAB键 [:cntrl:] 代表键盘上面的控制案件,即包括CR LF TAB DEL等 [:digit:] 代表数字 0-9 [:graph:] 除了空格键与TAB键外其他的所有键 [:lower:] 代表小写字符 a-z [:print:] 代表任何可以被打印出来的字符 [:punct:] 代表标点符号 即"';:!#$等 [: