我们再看一个更有趣的程序.这次我们来测试一个字符串是否和一个由简明模式(concise pattern)编码产生的描述相匹配.
在这些模式(pattern)里,一些字符或字符组合都有独特的意义,包括:
复制代码 代码如下:
[] 范围描述符 (比如,[a - z] 表示在a 到 z 范围内的一个字母)
\w 字母或数字;相当于 [0-9A-Za-z]
\W 非字母,数字
\s [ \t\n\r\f]空字符;相当于 [ \t\n\r\f]
\S 非空字符
\d [0-9]数字;相当于 [0-9]
\D 非数字字符
\b 退格符 (0x08) (仅在范围描述符内部时)
\b 字边界(word boundary) (在范围描述符外部时)
\B 非字边界
* 前面元素出现0或多次
+ 前面元素出现1或多次
{m,n} 前面元素最少出现m次,最多出现n次
? 前面元素最多出现1次;相当于 {0,1}
| 与前面或后面的表达式匹配
() 群( grouping)
那些模式中共同使用的古怪词汇叫做正则表达式.就象Perl一样,Ruby也用前斜杠(而不是双引号)将它们括起来.如果你以前从未使用过正则表达式,也许它们看起来除了规则(regular)什么都不是,但花上一点儿时间了解它们是明智的.当你需要对字符串进行模式匹配,查找或其它操作时,它的高效的表达能力能治好你的头痛(并节约很多行代码).
举个例子,设想我们想要测试一个字符串是否符合这样的描述信息"由小写f开头,跟一个大写字母,并可能跟许多非小写字母在后面."如果你是一个老练的C程序员,大概你的头脑里已经装满几十行程序了,对不对?承认吧,你难以控制住自己.在Ruby里,你只需要将你的字符串用正则表达式/^f[A-Z](^[a-z])*$/检验一下就可以了.
那"一个由<>括起来的16位数呢"?没问题.
复制代码 代码如下:
ruby> def chab(s) # "contains hex in angle brackets"
| (s =~ /<0(x|X)(\d|[a-f]|[A-F])+>/) != nil
| end
nil
ruby> chab "Not this one."
false
ruby> chab "Maybe this? {0x35}" # wrong kind of brackets
false
ruby> chab "Or this? <0x38z7e>" # bogus hex digit
false
ruby> chab "Okay, this: <0xfc0004>."
true
虽然,初看起来正则表达式挺让人头痛的,但你很快会因能够如此高效地表达出你心中的意思而感到满足.
下面是一个可以帮助你实验正则表达式的小程序,把它存为regx.rb,然后在命令行里输入'ruby regx.rb'运行.
复制代码 代码如下:
# Requires an ANSI terminal!
st = "\033[7m"
en = "\033[m"
while TRUE
print "str> "
STDOUT.flush
str = gets
break if not str
str.chop!
print "pat> "
STDOUT.flush
re = gets
break if not re
re.chop!
str.gsub! re, "#{st}\\&#{en}"
print str, "\n"
end
print "\n"
这个小程序要求输入两次,一次字符串,一次正则表达式.输入的字符串由正则表达式检验,然后用反视高亮度显示所有匹配部分.先别管细节,等会儿就有代码分析.
复制代码 代码如下:
str> foobar
pat> ^fo+
foobar
~~~
上面红色部分将在程序输入中以反视表示出.下面的"~~~"行是为了方便那些使用基于字符浏览器的人.
我们再试几个输入:
str> abc012dbcd555
pat> \d
abc012dbcd555
如果让你感到惊讶,看看本页开头部分的那个表格: \d与字母d无关,而是对应于单个数字.
如果有不止一种方法能匹配模式会怎样呢?
str> foozboozer
pat> f.*z
foozboozer
~~~~~~~~
之所以foozbooz被匹配而不只是fooz,是因为一个正则表达符尽可能匹配最长的子串.
下面是一个将冒号分隔的数字时间段从字符串中隔离出来的模式匹配.
str> Wed Feb 7 08:58:04 JST 1996
pat> [0-9]+:[0-9]+(:[0-9]+)?
Wed Feb 7 08:58:04 JST 1996
"=~"是一个用于匹配正则表达式的匹配(matching)运算符;它会返回在字符串里找到的匹配的位置,或者返回 nil 表示模式无法匹配.
ruby> "abcdef" =~ /d/
3
ruby> "aaaaaa" =~ /d/
nil
在这些模式(pattern)里,一些字符或字符组合都有独特的意义,包括:
复制代码 代码如下:
[] 范围描述符 (比如,[a - z] 表示在a 到 z 范围内的一个字母)
\w 字母或数字;相当于 [0-9A-Za-z]
\W 非字母,数字
\s [ \t\n\r\f]空字符;相当于 [ \t\n\r\f]
\S 非空字符
\d [0-9]数字;相当于 [0-9]
\D 非数字字符
\b 退格符 (0x08) (仅在范围描述符内部时)
\b 字边界(word boundary) (在范围描述符外部时)
\B 非字边界
* 前面元素出现0或多次
+ 前面元素出现1或多次
{m,n} 前面元素最少出现m次,最多出现n次
? 前面元素最多出现1次;相当于 {0,1}
| 与前面或后面的表达式匹配
() 群( grouping)
那些模式中共同使用的古怪词汇叫做正则表达式.就象Perl一样,Ruby也用前斜杠(而不是双引号)将它们括起来.如果你以前从未使用过正则表达式,也许它们看起来除了规则(regular)什么都不是,但花上一点儿时间了解它们是明智的.当你需要对字符串进行模式匹配,查找或其它操作时,它的高效的表达能力能治好你的头痛(并节约很多行代码).
举个例子,设想我们想要测试一个字符串是否符合这样的描述信息"由小写f开头,跟一个大写字母,并可能跟许多非小写字母在后面."如果你是一个老练的C程序员,大概你的头脑里已经装满几十行程序了,对不对?承认吧,你难以控制住自己.在Ruby里,你只需要将你的字符串用正则表达式/^f[A-Z](^[a-z])*$/检验一下就可以了.
那"一个由<>括起来的16位数呢"?没问题.
复制代码 代码如下:
ruby> def chab(s) # "contains hex in angle brackets"
| (s =~ /<0(x|X)(\d|[a-f]|[A-F])+>/) != nil
| end
nil
ruby> chab "Not this one."
false
ruby> chab "Maybe this? {0x35}" # wrong kind of brackets
false
ruby> chab "Or this? <0x38z7e>" # bogus hex digit
false
ruby> chab "Okay, this: <0xfc0004>."
true
虽然,初看起来正则表达式挺让人头痛的,但你很快会因能够如此高效地表达出你心中的意思而感到满足.
下面是一个可以帮助你实验正则表达式的小程序,把它存为regx.rb,然后在命令行里输入'ruby regx.rb'运行.
复制代码 代码如下:
# Requires an ANSI terminal!
st = "\033[7m"
en = "\033[m"
while TRUE
print "str> "
STDOUT.flush
str = gets
break if not str
str.chop!
print "pat> "
STDOUT.flush
re = gets
break if not re
re.chop!
str.gsub! re, "#{st}\\&#{en}"
print str, "\n"
end
print "\n"
这个小程序要求输入两次,一次字符串,一次正则表达式.输入的字符串由正则表达式检验,然后用反视高亮度显示所有匹配部分.先别管细节,等会儿就有代码分析.
复制代码 代码如下:
str> foobar
pat> ^fo+
foobar
~~~
上面红色部分将在程序输入中以反视表示出.下面的"~~~"行是为了方便那些使用基于字符浏览器的人.
我们再试几个输入:
str> abc012dbcd555
pat> \d
abc012dbcd555
如果让你感到惊讶,看看本页开头部分的那个表格: \d与字母d无关,而是对应于单个数字.
如果有不止一种方法能匹配模式会怎样呢?
str> foozboozer
pat> f.*z
foozboozer
~~~~~~~~
之所以foozbooz被匹配而不只是fooz,是因为一个正则表达符尽可能匹配最长的子串.
下面是一个将冒号分隔的数字时间段从字符串中隔离出来的模式匹配.
str> Wed Feb 7 08:58:04 JST 1996
pat> [0-9]+:[0-9]+(:[0-9]+)?
Wed Feb 7 08:58:04 JST 1996
"=~"是一个用于匹配正则表达式的匹配(matching)运算符;它会返回在字符串里找到的匹配的位置,或者返回 nil 表示模式无法匹配.
ruby> "abcdef" =~ /d/
3
ruby> "aaaaaa" =~ /d/
nil
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月23日
2024年11月23日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]