我注意到我的Ruby(1.9)脚本中存在一些极度延迟,经过一些挖掘后,它归结为正则表达式匹配。我在Perl和Ruby中使用以下测试脚本:Perl:$fname=shift(@ARGV);open(FILE,"){if(/(.*?)\|.*?SENDINGREQUEST.*?TID=(.*?),/){print"$1:$2\n";}}ruby:f=File.open(ARGV.shift)while(line=f.gets)if/(.*?)\|.*?SENDINGREQUEST.*?TID=(.*?),/.match(line)puts"#{$1}:#{$2}"endend我对两个脚本使
我正在尝试在Ruby的block内使用命名捕获组。$1仍然有效,但我想使用我提供的名称来引用它。"foo/(bar)".gsub(/(?\(.*?\))/x)do|match|puts"$1=#{$1}and$my_word=#{$my_word}"end预期:$1=(bar)and$my_word=(bar) 最佳答案 你在找"foo/(bar)".gsub(/(?\(.*?\))/x)do|match|puts"$1=#{$1}and$my_word=#{$~[:my_word]}"end
我正在阅读有关ruby的在线教程,发现了这个“通用分隔字符串”,%{aword}#=>"aword"%Q{aword}#=>"aword"%q{aword}#equivalenttosinglequotedversion.所以我在irb上试了一下,这就是我看到的2.0.0p247:025>%Q(hi)=>"hi"2.0.0p247:026>%q(the)=>"the"2.0.0p247:027>%q(th"e)=>"th\"e"2.0.0p247:028>%q(th'e)=>"th'e"2.0.0p247:029>%Q(h'i)=>"h'i"2.0.0p247:030>%Q(h"i
我不确定是我脑子坏了还是我只是想得太用力了。以下代码来自RubyKoans中的about_regular_expressions。deftest_asterisk_means_zero_or_moreassert_equal"abb","abbcccddddeeeee"[/ab*/]assert_equal"a","abbcccddddeeeee"[/az*/]assert_equal"","abbcccddddeeeee"[/z*/]#THINKABOUTIT:##Whenwould*failtomatch?end如何让*使匹配失败?当我说失败时,我假设他们的意思是他们希望asser
我正在尝试每四个字符拆分一个相当大的字符串。这就是我正在尝试的方式:big_string.split(/..../)这会生成一个nil数组。据我所知,这应该有效。当我将它插入onlinerubyregextest时它甚至会这样做. 最佳答案 试试扫描:$irb>>"abcd1234beefcake".scan(/..../)=>["abcd","1234","beef","cake"]或>>"abcd1234beefcake".scan(/.{4}/)=>["abcd","1234","beef","cake"]如果字符数不能被4整
给定:require'rubygems'require'nokogiri'value=Nokogiri::HTML.parse(AFooBCBarDEF"HTML_END我想做一些我可以在Hpricot中做的事情:divs=value.search('//div[@id^="para-"]')如何对XPath样式的元素进行模式搜索?我在哪里可以找到对我有帮助的文档?我没有在rdoc中看到这个。 最佳答案 使用xpath函数starts-with:value.xpath('//p[starts-with(@id,"para-")]')
通常当我的正则表达式模式看起来像这样时:http://www.microsoft.com/然后我必须像这样逃避它:string.match(/http:\/\/www\.microsoft\.com\//)有没有其他方法而不是像那样转义它?我希望能够像这样使用它http://www.microsoft.com,因为我不想转义所有模式中的所有特殊字符。 最佳答案 Regexp.new(Regexp.quote('http://www.microsoft.com/'))Regexp.quote简单地转义任何具有特殊正则表达式含义的字符;
我有一个字符串:s="123--abc,123--abc,123--abc"我尝试使用Ruby1.9的新功能“命名组”来获取所有命名组信息:/(?\d*)--(?\s*)/是否有像Python的findall那样返回matchdata集合的API?在这种情况下,我需要返回两个匹配项,因为123和abc重复两次。每个匹配数据都包含每个命名捕获信息的详细信息,因此我可以使用m['number']获取匹配值。 最佳答案 命名捕获只适用于一个匹配结果。Ruby的findall类比是String#scan.您可以使用scan结果作为数组,或将
我想匹配一个正则表达式并获取匹配字符串中的位置例如,"AustinTexasDallasTexas".match_with_posn/(Texas)/我想要match_with_posn返回类似:[6,17]其中6和17是单词Texas的两个实例的起始位置。有这样的吗? 最佳答案 使用Ruby1.8.6+,你可以这样做:require'enumerator'#Onlyfor1.8.6,newerversionsshouldnotneedthis.s="AustinTexasDallasTexas"positions=s.enum_f
只是想调试ruby中的正则表达式。当我打印正则表达式的内容时,它会在正则表达式的开头显示?-mix,即使这些字符不是表达式的一部分。请查看以下IRB输出以查看此说明irb(main):028:0*EXPR=/^a$/=>/^a$/irb(main):029:0>EXPR=>/^a$/irb(main):030:0>putsEXPR(?-mix:^a$)=>nil可以看到,当你使用puts打印出一个正则表达式的内容时,开头是?-mix。我应该为此担心吗?它来自哪里? 最佳答案 mix不是英文单词mix,而是Regexp的选项。参见