我在把它翻译成Ruby时遇到了麻烦。
下面是一段JavaScript,它做的正是我想做的事情:
function get_code(str){
return str.replace(/^(Z_.*): .*/,"$1");
}
我已经尝试过gsub、sub和replace,但似乎都不能满足我的期望。
下面是我尝试过的一些例子:
"Z_sdsd: sdsd".gsub(/^(Z_.*): .*/) { |capture| capture }
"Z_sdsd: sdsd".gsub(/^(Z_.*): .*/, "$1")
"Z_sdsd: sdsd".gsub(/^(Z_.*): .*/, "#{$1}")
"Z_sdsd: sdsd".gsub(/^(Z_.*): .*/, "\1")
"Z_sdsd: sdsd".gsub(/(.).*/) { |capture| capture }
发布于 2012-03-28 06:20:16
需要对双引号中的\1
进行转义。所以你想要
"Z_sdsd: sdsd".gsub(/^(Z_.*): .*/, "\\1")
或
"Z_sdsd: sdsd".gsub(/^(Z_.*): .*/, '\1')
参见the docs on gsub,其中显示“如果是双引号字符串,则两个反向引用的前面都必须有一个额外的反斜杠。”
也就是说,如果你只是想要比赛的结果,你可以这样做:
"Z_sdsd: sdsd".scan(/^Z_.*(?=:)/)
或
"Z_sdsd: sdsd"[/^Z_.*(?=:)/]
请注意,(?=:)
是一个非捕获组,因此:
不会出现在您的比赛中。
发布于 2014-02-08 07:12:26
"foobar".gsub(/(o+)/){|s|s+'ball'}
#=> "fooballbar"
发布于 2014-10-21 01:10:10
如果您需要使用正则表达式来过滤某些结果,然后仅使用捕获组,则可以执行以下操作:
str = "Leesburg, Virginia 20176"
state_regex = Regexp.new(/,\s*([A-Za-z]{2,})\s*\d{5,}/)
# looks for the comma, possible whitespace, captures alpha,
# looks for possible whitespace, looks for zip
> str[state_regex]
=> ", Virginia 20176"
> str[state_regex, 1] # use the capture group
=> "Virginia"
https://stackoverflow.com/questions/9898461
复制相似问题