1
while gets
2
if /[a-zA-Z0-9\.\-_]@[a-zA-Z0-9\.\-_]/
3
print
4
end
5
end
6
但是,对于Ruby来说,这样还不够简洁,我们可以这样2
3
4
5
6
呵呵,怎么样,吃惊了吧,一条语句就搞定了,ruby就是高效!
另外还有一个全局变量,$. 里面的内容是文件的总行数
还有其他的全局变量$&,&`,&' 这几个全局变量分别用于正则表达式中。
当你用match或者=~去匹配一个字符串和一个正则表达式时,结果是:$&存放字符串中匹配正则表达式的部分,$`存放字符串中$&部分的前一个字符串,$'存放字符串中$&部分的后一个字符串。
比如
str="good day! woodfish1988@163.com It's a email"
reg=/[a-zA-Z0-9\-\._]+@[a-zA-Z0-9\-\._]+/
reg=~str
puts $`,$&,$'
reg=/[a-zA-Z0-9\-\._]+@[a-zA-Z0-9\-\._]+/
reg=~str
puts $`,$&,$'
结果是
good day!
woodfish1988@163.com
It's a email
同时,在匹配后全局标量$1..$9里面存放的匹配于正则表达式中的各个小内容(也就是由括号括起来的内容,具体请看正则表达式教程)
例如:
code="<a href='http://www.google.com'>Google</a>"
reg=/<a href='(.+)'>(.+)<\/a>/
reg=~code
puts $1,$2
reg=/<a href='(.+)'>(.+)<\/a>/
reg=~code
puts $1,$2
结果是
http://www.google.com
Google