4

有一个简单的问题:我有一个这样的文件:

ip-10-0-12-84.eu-west-1.compute.internal, master, instnum=1, Running
.....
.....
ip-10-0-26-118.eu-west-1.compute.internal, master_rabbit, instnum=4, Running
ip-10-0-26-116.eu-west-1.compute.internal, master_rabbit, instnum=5, Running
.....
ip-10-0-26-68.eu-west-1.compute.internal, sql_master, instnum=9, Running
ip-10-0-13-244.eu-west-1.compute.internal, nat, instnum=2, Running

我的目标是阅读文件,跳过注释(以 开头#)、空行/空行以及其中包含nat或的行master。我试过这个:

open('/tmp/runnings.txt').each do |line|
    next if line =~ /(^\s*(#|$)|nat|master)/

这几乎可以工作,但它也消除了其中的master_rabbit线条sql_master。我怎样才能只选择master而不是任何其他组合?可以在同一行完成吗?干杯!!

4

3 回答 3

6

单词边界锚可以在这里提供帮助:

/^\s*(#|$)|\b(nat|master)\b/
于 2013-11-04T10:46:18.543 回答
1

我觉得这不是应该用正则表达式解决问题的地方。当然,您现在可以使用一个,但是如果您要排除新的关键字,以后将很难理解并且难以编辑。

我喜欢这种解决问题的方法:

FILE_PATH = '/tmp/runnings.txt'
keywords  = ['nat', 'master']
empty_lines_and_comments     = ->x{ x.chomp.empty? or x.start_with?('#') }
lines_containing_bad_keyword = ->x{ keywords.include? x[1] } # Keywords at index 1

data = File.readlines(FILE_PATH)
           .reject(&empty_lines_and_comments)
           .map{|line| line.chomp.split(', ')}
           .reject(&lines_containing_bad_keyword)
于 2013-11-04T11:42:54.220 回答
1
open("/tmp/runnings.txt").each_line
.grep(/\A(?!\s*#)(?!.*\bnat\b)(?!.*\bmaster\b).*\S/) do |line|
  ...
end
于 2013-11-04T10:46:27.247 回答