tzbm123456 发表于 2019-10-12 10:16:44

Ruby正则表达式

正则表达式

tzbm123456 发表于 2019-10-12 10:23:52

本帖最后由 tzbm123456 于 2019-10-12 10:35 编辑

aa="第-21dFaas层_00轴网"
aa.gsub(/第-*层/,'第5层')
返回:第5层_00轴网


aa="第21dFaas层_00轴网"
aa.gsub(/(第-*层)|(第*层)/,'第5层')
返回:第5层_00轴网

tzbm123456 发表于 2019-12-28 18:16:11

本帖最后由 tzbm123456 于 2019-12-28 18:17 编辑

正则表达式常用语法一、正则表达式简单语法——基本符号:1、^表示匹配字符串的开始位置(例外用在中括号中[ ] 时,可以理解为取反,表示不匹配括号中字符串)2、$表示匹配字符串的结束位置3、*表示匹配零次到多次4、+表示匹配一次到多次 (至少有一次)5、?表示匹配零次或一次6、.表示匹配单个字符 7、|表示为或者,两项中取一项8、() 小括号表示匹配括号中全部字符9、[] 中括号表示匹配括号中一个字符 范围描述 如10、{} 大括号用于限定匹配次数如 {n}表示匹配n个字符{n,}表示至少匹配n个字符{n,m}表示至少n,最多m11、\转义字符 如上基本符号匹配都需要转义字符   如 \*表示匹配*号12、\w 表示英文字母和数字\W非字母和数字13、\d表示数字   \D非数字二、常用的正则表达式1、匹配中文字符的正则表达式: [\u4e00-\u9fa5]2、匹配双字节字符(包括汉字在内):[^\x00-\xff]3、匹配空行的正则表达式:\n[\s| ]*\r4、匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*) \/>/ 5、匹配首尾空格的正则表达式:(^\s*)|(\s*$)6、匹配IP地址的正则表达式:/(\d+)\.(\d+)\.(\d+)\.(\d+)/g //7、匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*8、匹配网址URL的正则表达式:http://(/[\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?9、sql语句:^(select|drop|delete|create|update|insert).*$10、非负整数:^\d+$ 11、正整数:^**$ 12、非正整数:^((-\d+)|(0+))$ 13、负整数:^-**$ 14、整数:^-?\d+$ 15、非负浮点数:^\d+(\.\d+)?$ 16、正浮点数:^((0-9)+\.**)|(**\.+)|(**))$ 17、非正浮点数:^(((-\d+\.\d+)?)|(0+(\.0+)?))$ 18、负浮点数:^(-((正浮点数正则式)))$ 19、英文字符串:^+$ 20、英文大写串:^+$ 21、英文小写串:^+$ 22、英文字符数字串:^+$ 23、英数字加下划线串:^\w+$ 24、E-mail地址:^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$ 25、URL:^+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\s*)?$ 或:^http:\/\/+\.+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"\"])*$26、邮政编码:^\d{5}$27、中文:^[\u0391-\uFFE5]+$28、电话号码:^((\d2,3)|(\d{3}\-))?(0\d2,3|0\d{2,3}-)?\d{6,7}(\-\d{1,4})?$29、手机号码:^((\d2,3)|(\d{3}\-))?13\d{9}$30、双字节字符(包括汉字在内):^\x00-\xff31、匹配首尾空格:(^\s*)|(\s*$)(像vbscript那样的trim函数)32、匹配HTML标记:<(.*)>.*<\/\1>|<(.*) \/> 33、匹配空行:\n[\s| ]*\r34、提取信息中的网络链接:(h|H)(r|R)(e|E)(f|F) *= *('|")?(\w|\\|\/|\.)+('|"| *|>)?35、提取信息中的邮件地址:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*36、提取信息中的图片链接:(s|S)(r|R)(c|C) *= *('|")?(\w|\\|\/|\.)+('|"| *|>)?37、提取信息中的IP地址:(\d+)\.(\d+)\.(\d+)\.(\d+)38、提取信息中的中国手机号码:(86)*0*13\d{9}39、提取信息中的中国固定电话号码:(\d3,4|\d{3,4}-|\s)?\d{8}40、31、提取信息中的中国电话号码(包括移动和固定电话):(\d3,4|\d{3,4}-|\s)?\d{7,14}41、提取信息中的中国邮政编码:{1}(\d+){5}42、提取信息中的浮点数(即小数):(-?\d*)\.?\d+43、提取信息中的任何数字 :(-?\d*)(\.\d+)? 44、IP:(\d+)\.(\d+)\.(\d+)\.(\d+)45、电话区号:/^0\d{2,3}$/46、腾讯QQ号:^**$47、帐号(字母开头,允许5-16字节,允许字母数字下划线):^{4,15}$48、中文、英文、数字及下划线:^[\u4e00-\u9fa5_a-zA-Z0-9]+$       

tzbm123456 发表于 2020-5-24 09:13:22

本帖最后由 tzbm123456 于 2020-5-24 10:05 编辑

1、一位英文字符(大写或小写):/^{1,1}$/ (或/^$/)
说明:^——字符串的开始
   $——字符串的结束
   {n,m}——至少n次,至多m次
2、任意英文字符(大写或小写):/^*$/
说明:^——字符串的开始
   $——字符串的结束
   *——任意次数

tzbm123456 发表于 2021-10-26 17:14:03

aa="0.000(建筑4)"
b=aa[/[\u4e00-\u9fa5]+/]
p b


打印值为:'建筑'

页: [1]
查看完整版本: Ruby正则表达式