js 正则表达式提取某一段字符
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js 正则表达式提取某一段字符相关的知识,希望对你有一定的参考价值。
BEGIN CONST a,b=10,c END IF a>10 && (a+c<20 || b>c) THEN RETURN true END ELSE RETURN false END END END
===============
1:我想取出 IF 和 THEN 之间的 a>10 && (a+c<20 || b>c),怎么用正则取出??然后用split按&&分隔。
2:取出之后,我如何用正则将 a>10 拆分成 a ,>,10 三份,中间的符号不一定为> ,有可能<,=,>=,我改如何拆分
str=str.replace(/\\s/g,"");//取掉空格
str=str.match(/IF(\\S*)THEN/)[1];//正则取出IF和THEN之间的字符串
str=str.split("&&");//按照&&分组
var str_end=str[0].split('>'); //按照>分组
alert(str_end);//最终结果为str_end[0]=a str_end[1]=10 ; 参考技术A
正则表达式(英语:Regular Expression,在代码中常简写为regex、regexp或RE)使用单个字符串来描述、匹配一系列符合某个句法规则的字符串搜索模式。
搜索模式可用于文本搜索和文本替换。
什么是正则表达式?
正则表达式是由一个字符序列形成的搜索模式。
当你在文本中搜索数据时,你可以用搜索模式来描述你要查询的内容。
正则表达式可以是一个简单的字符,或一个更复杂的模式。
正则表达式可用于所有文本搜索和文本替换的操作。
语法
/正则表达式主体/修饰符(可选)
其中修饰符是可选的。
实例:
var patt = /runoob/i
实例解析:
/runoob/i 是一个正则表达式。
runoob 是一个正则表达式主体 (用于检索)。
i 是一个修饰符 (搜索不区分大小写)。
使用字符串方法
在 javascript 中,正则表达式通常用于两个字符串方法 : search() 和 replace()。
search() 方法 用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串,并返回子串的起始位置。
replace() 方法 用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。
search() 方法使用正则表达式
实例
使用正则表达式搜索 "Runoob" 字符串,且不区分大小写:
var str = "Visit Runoob!";
var n = str.search(/Runoob/i);
输出结果为:
6
尝试一下 »
search() 方法使用字符串
search 方法可使用字符串作为参数。字符串参数会转换为正则表达式:
实例
检索字符串中 "Runoob" 的子串:
var str = "Visit Runoob!";
var n = str.search("Runoob");
尝试一下 »
replace() 方法使用正则表达式
实例
使用正则表达式且不区分大小写将字符串中的 Microsoft 替换为 Runoob :
var str = document.getElementById("demo").innerhtml;
var txt = str.replace(/microsoft/i,"Runoob");
结果输出为:
Visit Runoob!
尝试一下 »
replace() 方法使用字符串
replace() 方法将接收字符串作为参数:
var str = document.getElementById("demo").innerHTML;
var txt = str.replace("Microsoft","Runoob");
尝试一下 »
你注意到了吗?
正则表达式参数可用在以上方法中 (替代字符串参数)。
正则表达式使得搜索功能更加强大(如实例中不区分大小写)。
正则表达式修饰符
修饰符 可以在全局搜索中不区分大小写:
修饰符
描述
i 执行对大小写不敏感的匹配。
g 执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。
m 执行多行匹配。
正则表达式模式
方括号用于查找某个范围内的字符:
表达式
描述
[abc] 查找方括号之间的任何字符。
[0-9] 查找任何从 0 至 9 的数字。
(x|y) 查找任何以 | 分隔的选项。
元字符是拥有特殊含义的字符:
元字符
描述
\\d 查找数字。
\\s 查找空白字符。
\\b 匹配单词边界。
\\uxxxx 查找以十六进制数 xxxx 规定的 Unicode 字符。
量词:
量词
描述
n+ 匹配任何包含至少一个 n 的字符串。
n* 匹配任何包含零个或多个 n 的字符串。
n? 匹配任何包含零个或一个 n 的字符串。
使用 RegExp 对象
在 JavaScript 中,RegExp 对象是一个预定义了属性和方法的正则表达式对象。
使用 test()
test() 方法是一个正则表达式方法。
test() 方法用于检测一个字符串是否匹配某个模式,如果字符串中含有匹配的文本,则返回 true,否则返回 false。
以下实例用于搜索字符串中的字符 "e":
实例
var patt = /e/;
patt.test("The best things in life are free!");
字符串中含有 "e",所以该实例输出为:
true
尝试一下 »
你可以不用设置正则表达式的变量,以上两行代码可以合并为一行:
/e/.test("The best things in life are free!")
使用 exec()
exec() 方法是一个正则表达式方法。
exec() 方法用于检索字符串中的正则表达式的匹配。
该函数返回一个数组,其中存放匹配的结果。如果未找到匹配,则返回值为 null。
以下实例用于搜索字符串中的字母 "e":
Example 1
/e/.exec("The best things in life are free!");
字符串中含有 "e",所以该实例输出为:
e
尝试一下 »
更多实例
JS 判断输入字符串是否为数字、字母、下划线组成
JS 判断输入字符串是否全部为字母
JS 判断输入字符串是否全部为数字
完整的 RegExp 参考手册
完整的 RegExp 对象参考手册,请参考我们的 JavaScript RegExp 参考手册。
该参考手册包含了所有 RegExp 对象的方法和属性。
JavaScript 类型转换
JavaScript 错误 – Throw、Try 和 Catch
1 篇笔记qq1056125478
105***5478@qq.com
正则表达式表单验证实例:
/*是否带有小数*/function isDecimal(strValue )var objRegExp= /^\\d+\\.\\d+$/;
return objRegExp.test(strValue); /*校验是否中文名称组成 */function ischina(str) var reg=/^[\\u4E00-\\u9FA5]2,4$/; /*定义验证表达式*/ return reg.test(str); /*进行验证*//*校验是否全由8位数字组成 */function isStudentNo(str) var reg=/^[0-9]8$/; /*定义验证表达式*/ return reg.test(str); /*进行验证*//*校验电话码格式 */function isTelCode(str) var reg= /^((0\\d2,3-\\d7,8)|(1[3584]\\d9))$/; return reg.test(str);/*校验邮件地址是否合法 */function IsEmail(str) var reg=/^\\w+@[a-zA-Z0-9]2,10(?:\\.[a-z]2,4)1,3$/; return reg.test(str);
一个通用的php正则表达式匹配或检测或提取特定字符类
在php开发时,日常不可或缺地会用到正则表达式,可每次都要重新写,有时忘记了某一函数还要翻查手册,所以,抽空写了一个关于日常所用到的正则表达式区配类,便于随便移置调用.(^_^有点偷懒).
/*///////////////////////////////////////////////////////////// * 类MatchAll功能:主要用于php日常所用到的几种检测匹配或提取特定字符.// * 主要参数设置说明: $target_str 为目标字符即需要检测的字符或数字。// * $isFind true:提取出匹配字符;false:单纯检测是否存在特定字符. // * $isTotal true: 完全匹配模式;false:部分匹配模式. // * @author: purpen // * @email: [email protected] // * @data: 2007-07-29 // *///////////////////////////////////////////////////// class MatchAll { /** * 功能: 用于检测IP地址是否合法或从字符串中提取IP字符. * * @param string $target_str * @param boolean $isFind * @param boolean $isTotal * @return mixed */ public static function IP_match($target_str, $isFind=false, $isTotal=false) { //采取的匹配模式 if ($isTotal == true) { $pattern = "/^(\d{1,3}\.){3}\d{1,3}$/"; }else{ $pattern = "/(\d{1,3}\.){3}\d{1,3}/"; } return self::get_match_result($target_str, $pattern, $isFind); } /** * 功能: 用于检测身份证号是否合法或从字符串中提取出身份证号字符. * * @param mixed $target_str * @param boolean $isFind * @param boolean $isTotal * @return mixed */ public static function IDCard_match($target_str, $isFind=false, $isTotal=false){ //采取的匹配模式 if ($isTotal == true){ $pattern = "/^(\d{18}|\d{17}X|\d{15})$/"; }else{ $pattern = "/(\d{18}|\d{17}X|\d{15})/"; } return self::get_match_result($target_str, $pattern, $isFind); } /** * 功能: 用于检测电话号码是否合法或从字符长串中提取出电话号码. * @param mixed $target_str * (例如: 010-87965421、(010)87965421、87965421、0394-5568447、(0394)5568447、5568447) * @param boolean $isFind * @param boolean $isTotal * @return mixed */ public static function phone_match($target_str, $isFind=false, $isTotal=false) { //采用匹配模式 if ($isTotal == true) { $pattern = "/^((\(?\d{3,4}\))?|(\d{3,4}-)?)\d{7,8}$/"; }else{ $pattern = "/((\(?\d{3,4}\))?|(\d{3,4}-)?)\d{7,8}/"; } return self::get_match_result($target_str, $pattern, $isFind); } /** * 功能:用于检测邮政编码是否合法或从字符长串中提取出邮政编码字符. * * @param mixed $target_str * @param boolean $isFind * @param boolean $isTotal * @return mixed */ public static function postalcode_match($target_str, $isFind=false, $isTotal=false) { //采取的匹配模式 if ($isTotal == true) { $pattern = "/^\d{6}$/"; }else{ $pattern = "/\d{6}/"; } return self::get_match_result($target_str, $pattern, $isFind); } /** * 功能: 用于完全匹配、部队匹配或提出网络url的方法. * @param string $target_str * @param boolean $isFind 是否提取出匹配目标 * @param boolean $isTotal 是否完全匹配 * @return mixed */ public static function neturl_match ($target_str, $isFind=false, $isTotal=false) { //采用的匹配模式 if ($isTotal == true) { $pattern = "/^(http\:\/\/)?[a-zA-Z0-9]+(\.[a-zA-Z0-9]+)*.+$/"; }else{ $pattern = "/(http\:\/\/)?[a-zA-Z0-9]+(\.[a-zA-Z0-9]+)*/"; } return self::get_match_result($target_str, $pattern, $isFind); } /** * 功能: 用于检测email是否合法或从字符串中提取出email字符串. * @param string $target_str * @param boolean $isFind 是否提取出字符串 * @param boolean $isTotal是否完全匹配 * @return mixed */ public static function email_match ($target_str, $isFind=false, $isTotal=false){ //采取的匹配模式 if ($isTotal == true){ $pattern = "/^[_a-zA-Z0-9-]+(\.[_a-zA-Z0-9-]+)*@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)*$/"; }else{ $pattern = "/[_a-zA-Z0-9-]+(\.[_a-zA-Z0-9-]+)*@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)*/"; } return self::get_match_result($target_str, $pattern, $isFind); } /** * 功能:用于完全匹配、部分匹配或提取出钱币数字的方法. * @param mixed $target_str * @param boolean $isFind * @param boolean $isTotal * @return mixed */ public static function money_match($target_str, $isFind=false, $isTotal=false) { //采用完全匹配 if ($isTotal == true) { $pattern = "/^[0-9]{1,3}(,[0-9]{3})*(\.[0-9]+)?$/"; }else{//部分匹配 $pattern = "/[0-9]{1,3}(,[0-9]{3})*(\.[0-9]+)?/"; } return self::get_match_result($target_str, $pattern, $isFind); } /** * 功能:开始匹配目标字符串动作. * * @param mixed $target_str * @param string $pattern * @param boolean $isFind * @return mixed */ public function get_match_result($target_str, $pattern, $isFind) { //是否提取出匹配目标 if ($isFind == true) { preg_match($pattern, $target_str, $result); }else{ $result = preg_match($pattern, $target_str); } return $result; } /** * 功能: 用于匹配测试 * @param str $target_str //$target_str = "select a, b, c, d from d"; */ public function all_match($target_str) { $pattern = "/select(.+)from(\s[a-zA-Z0-9])/i"; preg_match($pattern, $target_str, $result); $fields = split(",", $result[1]); print $result[2]; print ""; return $fields; } }
以上是关于js 正则表达式提取某一段字符的主要内容,如果未能解决你的问题,请参考以下文章
java 正则表达式 字符串中提取日期 例如:某一节目第20140502期