草庐IT

regexp_extract

全部标签

Ruby on Rails regexp equals-tilde 与 array include 用于检查选项列表

我正在使用Rails3.2.3和Ruby1.9.3p0。我发现我经常需要确定某个字符串是否出现在选项列表中。看来我可以使用Ruby数组.includemethod:或正则表达式equals-tildematchshorthand用竖线分隔选项:就性能而言,一个比另一个好吗?还有更好的方法吗? 最佳答案 总结:Array#include?包含String元素,在接受和拒绝输入时均胜出,对于您的示例只有三个可接受的值。对于要检查的更大的集合,看起来Set#include?和String元素可能会获胜。如何测试我们应该根据经验对此进行测试

ruby - 为什么 `Symbol#match` 的行为与 `String#match` 和 `Regexp#match` 不同?

String#match和Regexp#match在匹配成功时返回一个MatchData:"".match(//)#=>#//.match("")#=>#//.match(:"")#=>#但是Symbol#match返回匹配位置(如String#=~)::"".match(//)#=>0为什么Symbol#match表现不同?有用例吗? 最佳答案 我将其报告为Ruby核心中的错误:https://bugs.ruby-lang.org/issues/11991.让我们看看他们会怎么说。更新被质疑的行为似乎是一个错误。似乎从Ruby2.

ruby - 安装 RDoc 文档时出错 : incompatible encoding regexp match

上周,在一些gem安装或gem更新操作中,我收到了与这些类似的错误:ERROR:Whilegeneratingdocumentationforsinatra-1.3.1...MESSAGE:errorgeneratingC:/RailsInstaller/Ruby1.9.2/lib/ruby/gems/1.9.1/doc/sinatra-1.3.1/rdoc/README_de_rdoc.html:incompatibleencodingregexpmatch(UTF-8regexpwithIBM437string)(Encoding::CompatibilityError)类似的:E

ruby - regexp\k<name+0> 中的 "+0"是什么意思?

我是Ruby中正则表达式的新手,我似乎找不到任何关于\k内容的可靠文档。方法。这是+0我没有得到的部分。这是一个例子——这个正则表达式匹配回文:\A(?(?:(?\w)\g\k|\w))\z当我删除+0在\k它不再正确匹配。我的测试:>>/\A(?(?:(?\w)\g\k|\w))\z/.match"aabbcdcbbaa"#=>#>>/\A(?(?:(?\w)\g\k|\w))\z/.match"aabbcdcbbaa"#=>nil我所做的就是删除+0.我还没有找到任何文档或示例,任何人都可以指出正确的方向吗? 最佳答案 \k与(

ruby-on-rails - 如何以智能方式从多维数组中获取 "extract"值?

我正在使用RubyonRails3.2.2和Ruby1.9.2。给定以下多维数组:[["value1","value1_other"],["value2","value2_other"],["value3","value3_other"]]我想得到(注意:我想只“提取”所有“嵌套”数组的第一个值):["value1","value2","value3"]我怎样才能以聪明的方式做到这一点? 最佳答案 您可以使用Array#collect为外部数组的每个元素执行一个block。要获取第一个元素,请传递一个索引数组的block。arr.c

ruby 正则表达式 : extract text between quotes

从文本中提取引用词/短语的最佳方法是什么?我的尝试无法正常工作:text.scan(/\"([^"]+)/) 最佳答案 我想你想要:text.scan(/"([^"]*)"/)它适用于Rubular. 关于ruby正则表达式:extracttextbetweenquotes,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4799644/

ruby - Regexp.escape 不转义正斜杠?

在IRB中,如果我将类似“/domain/path”的字符串传递给Regexp.escape,它只会返回相同的字符串。我认为正斜杠应该用反斜杠转义?我在这里遗漏了什么吗? 最佳答案 此外,如果您指定其他类型的分隔符(或创建Regexp类的实例),您需要转义/字符的唯一原因是因为它是正则表达式的分隔符你不会有这个问题:/^hello\/world$/#escaping'/'justtosay:"thisisnottheend"%r"^hello/world$"#noneedforescaping'/'Regexp.new('^hell

ruby - Regexp.last_match 线程安全吗?

这是我正在查看的代码:defmethod_missing(id,*args)returnself.find(Regexp.last_match(1),args[0])ifid.id2name=~/find_by_(.+)/raiseNoMethodErrorend如果我有多个线程调用Regexp.last_match会怎样?如果我有多个线程使用method_missing方法调用对象会怎样? 最佳答案 Ruby1.9.2平台文档声明调用Regexp.last_match等同于读取特殊的$~全局变量。摘自“TheRubyProgram

ruby - 如何在许多匹配项中使用 ruby​​ gsub Regexp?

我的csv文件内容在引用的文本中有双引号test,first,line,"youarea"kind"man",thanksagain,second,li,"my"boss"isyou",good我需要用“”替换每一个前面或后面没有逗号的双引号test,first,line,"youarea""kind""man",thanksagain,second,li,"my""boss""isyou",good所以"被替换为""我试过了x.gsub(/([^,])"([^,])/,"#{$1}\"\"#{$2}")但没用 最佳答案 您的正则表

ruby-on-rails - ruby 正则表达式错误 : incompatible encoding regexp match (ASCII-8BIT regexp with UTF-8 string)

我遇到了两个错误,都与编码有关并且都相关。我在启动WEBrick时遇到的第一个错误(技术上是警告):/Users/USERNAME/example/config/initializers/bb-ruby.rb:54:warning:invalidUnicodeProperty\P:/\:\-?\P/它所指的行是:/\:\-?\P/,这只是一些正则表达式,最终是这个block的一部分:@@tags['Razzing']=[/\:\-?\P/,'','Razzing',':P',:razzing]然后,我在解析一些字符串时也得到了以下错误(大概是由于同一行)...Encoding::Com