我有一个主文本文件和异常文件,我想用主文件和递增计数器匹配异常文件中的所有单词,但诀窍是使用通配符。
我可以不用通配符,如下所示:
words = %w(aaa aab acc ccc AAA)
stop = %q(/aa./)
words.each do |x|
if x.match(/aa./)
puts "yes for #{x}"
else
puts "no for #{x}"
end
end=>
yes for aaa
yes for aab
no for acc
no for ccc
yes for AAA同样,这将是最好的方式,使用数组或其他方式。
编辑:很抱歉给您带来了混乱。是的,stop有多个通配符,我希望根据这些通配符匹配所有单词。
words = %w(aaa aab acc ccc AAA)
stop = %q(aa* ac* ab*)谢谢
发布于 2010-04-20 22:18:35
对你的需求的描述非常模糊。但是partition或select方法都可以为您工作:
words = %w(aaa aab acc ccc AAA)
re = %r(aa.)i
p words.partition {|word| word.match(re)} # => [["aaa", "aab", "AAA"], ["acc", "ccc"]]
p words.select {|word| word.match(re)} # => ["aaa", "aab", "AAA"]更新
根据你的上一条评论:
stops= %q(aa* ac* ab*)
stops.split.collect do |wildcard|
re = Regexp.new(wildcard, Regexp::IGNORECASE)
words.select {|word| word.match(re)}
end
# => [["aaa", "aab", "acc", "AAA"], ["aaa", "aab", "acc", "AAA"], ["aaa", "aab", "acc", "AAA"]]如果这些结果让您感到惊讶,那么您可能需要学习更多关于正则表达式的知识,正则表达式与glob样式的模式有很大的不同,而且功能更强大。Ruby不会对字符串进行全局匹配。
https://stackoverflow.com/questions/2674731
复制相似问题