Ruby大部分的内置类型都和其它的编程语言很相似。主要有strings,integers,floats,arrays等等。然而,只有脚本语言,如Ruby,Perl,和awk等提供了内置表达式类型的支持。正则表达式尽管比较隐蔽,但却是一个很强大的文本处理工具。

正则表达式是使用指定的模式匹配字符串的一种简单的方法。在Ruby中,创建正则表达式的典型方式是把模式写在两个斜线之间/pattern/。

毕竟,Ruby就是Ruby,正则表达式也是对象,也能像对象般操作。

例如,你可以使用下面的正则表达式写一个模式,它匹配一个字符串中包含有Perl或Python。

<!--more-->

/Perl|Python/

在正斜线体内,是两个我们要匹配的字符串,它们使用"|"分隔。这个管道符的意思是"左边的或者右边的",在这个模式中是Perl或者Python。

你还可以在模式中使用括号,就像是在算术表达式中使用的那样,因此这个模式还可以写成

/P(erl|ython)/

你还可以在模式中指定重复。例如加号,/ab+c/匹配字符串中一个a后面有一个或多个b然后跟着是一个c。把加号换成星号,/ab*c/创建的正则表达式是匹配一个a后面跟着0个或多个b然后跟着是一个c。

你还可以在模式中匹配一组字符。常用的字符类型例子有\s,它匹配一个空白字符(space,tab,换行符,等等);\d匹配任意数字;\w匹配任意的典型单词字符。句号(.)匹配(基本上)任意字符。

我们把所有这些组合起来,做成实用的正则表达式。

/\d\d:\d\d:\d\d/ # a time such as 12:34:56
/Perl.*Python/  # Perl, zero or more other chars, then Python
/Perl Python/  # Perl, a space, and Python
/Perl *Python/  # Perl, zero or more spaces, and Python
/Perl +Python/  # Perl, one or more spaces, and Python
/Perl\s+Python/ # Perl, whitespace characters, then Python
/Ruby (Perl|Python)/ # Ruby, a space, and either Perl or Python

一但创建了一个模式,不能使用它是件很郁闷的事情。匹配操作符=~用来对一个字符串进行正则表达式匹配。如果匹配成功,=~返回第一次匹配成功的位置,否则它返回nil。也就是说,你可以在if和while的条件声明中使用正则表达式。例如下面的代码片段,

如果字符串中包含有文本Perl或Python时,输出一条信息。

puts "Scripting language mentioned: #{line}" if line =~ /Perl|Python/

你能使用Ruby替换所有出现有Perl和Python的地方。

line.gsub(/Perl|Python/, 'Ruby')

从iHower的Ruby on Rails实战圣经中摘一个示例,用正则表达式抓取手机号码:

phone = "139-1234-5678"
if phone =~ /(\d{3})-(\d{4})-(\d{4})/
 start_with = $1
 mid_num = $2
 end_as = $3
end

一般规则(为正常显示,都放在代码块内)

  • /a/匹配字符a。   
  • /\"Mr","Mrs","Mr.","Mrs."。
  • *代表0或多个字符。/Hello*/匹配"Hello","HelloJack"。
  • +代表1或多个字符。/a+c/匹配:"abc","abbdrec"等等。
  • /d{3}/匹配3个数字。
  • /d{1,10}/匹配1-10个数字。
  • /d{3,}/匹配3个数字以上。
  • /([A-Z]\d){5}/匹配首位是大写字母,后面4个是数字的字符串。

正则表达式操作

String和RegExp均支持=~和match两个查询匹配方法:

puts "I can say my name" =~ /name/ #-> 13

a = /name/.match("I can say my name, my name I can say") #-> a is MatchData
puts a[0] #-> name

可以看出,如果能够匹配,=~返回匹配的字符串位置,而match返回一个MatchData对象。如果不匹配,则返回nil。MatchData可以取出其中符合各个子匹配(或子模式)的内容,看下面的例子:

b1=/[A-Za-z]+,[A-Za-z]+,Mrs"Jack,Wang,Mrs., nice person")
puts b1[0] #-> Jack,Wang,Mrs

b2=/(([A-Za-z]+),([A-Za-z]+)),Mrs"Jack,Wang,Mrs., nice person:)
puts b2[0] #-> Jack,Wang,Mrs
puts b2[1] #-> Jack,Wang
puts b2[2] #-> Jack
puts b2[3] #-> Wang

m[0]返回匹配匹配主表达式的字符串,下面的方法是等同的:m[n]==m.captures[n]

Ruby也自动的为我们填写一些全局变量,它们以数字做名,$1, $2, 等等,$1包含的是正则表达式中从左侧开始的第一对小括号内的子模式所匹配的字符串,以此类推。我们看出匹配时,是从外到内,从左到右的顺序。

贪婪量词和不贪婪量词

量词*(表示零个或多个)和+(表示一个或多个)是贪婪的,它们会匹配尽可能多的字符,我们可以在*和+后面加一个"htmlcode">

teststr="abcd!efg!"
match=/.+!/.match(teststr)
puts match[0] #-> abcd!efg!

limitmatch=/.+"htmlcode">
c=/\b\w+\b/.match("!!Stephen**")

puts c[0] #-> Stephen

前视断言

前视断言表示想要知道下一个指定的是什么,但并不匹配

肯定的前视断言 (?=)
假设我们想要匹配一个数的序列,该序列以一个圆点结束,但并不想把圆点作为模式匹配的一部分

teststr="123 456 789. 012"
m=/\d+("htmlcode">
teststr="a.c"
re=/#{Regexp.escape(teststr)}/
puts re.match("a.c")[0] #-> a.c
test=re.match("abc")
puts test[0] #-> Nil

正则表达式转换成字符串

puts /abc/.inspect #-> /abc/

使用正则表达式的常见方法:

  • 用于if和while等
  • 用于gsub、grep等
  • 用于find_all、scan等

例如,puts "test 1 2 and test 3 4".scan(/\d/)会输出["1","2","3","4"]。

广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。