2

我遇到了这个正则表达式的问题,它似乎没有抓住标题(最后一个 '.' 之后的所有内容)我已经在多个来源上测试了正则表达式,它们似乎都抓住了正确的分组。我做错了扫描功能吗?

##### data.csv file #####
## Web_Sites.Shopping.Newegg,...
## Web_Sites.Shopping.Newegg_Secure,...
## Web_Sites.Shopping.O'Reilly_Books,...
## Web_Sites.Shopping.PackageTrackr,...
#####

## Grab the title from the list
regex = '([\w_-]+)$'

## Open the CSV File
data_file = CSV.open("data.csv", "r")

## Set the file we will append the data.
my_file = File.new("titles.csv", 'a')

## For each line in the data file, get the correct title
data_file.each do |data|
   note = data[0]
   title = note.scan(regex)
   my_file.print "#{note} : #{title}"
end

谢谢你,
LF4

4

1 回答 1

6

您没有给出scan正则表达式参数,而是给它一个纯字符串,并且该字符串'([\w_-]+)$'可能不会出现在您的任何地方,note因此scan不会做任何有用的事情。您想使用Regexp类来创建和存储您的正则表达式:

regex = Regexp.new('([\w_-]+)$')

或者(谢谢Kudo)您可以使用其中一种正则表达式文字形式:

regex = /([\w_-]+)$/
regex = %r{([\w_-]+)$}

然后将该实例传递Rexexpnote.scan

note.scan(regex)
于 2011-06-25T05:10:38.393 回答