我有一个脚本telnet到一个框,运行一个命令,并保存输出。之后我运行另一个脚本,它解析输出文件,将其与位于另一个文件中的关键字进行比较以进行匹配。如果一条线匹配,它应该将整条线(从原始的telnet输出)保存到一个新文件。
以下是处理解析文本的脚本部分:
def parse_file
filter = []
temp_file = File.open('C:\Ruby193\scripts\PARSED_TRIAL.txt', 'a+')
t = File.open('C:\Ruby193\scripts\TRIAL_output_log.txt')
filter = File.open('C:\Ruby193\scripts\Filtered_text.txt').readlines
t.each do |line|
filter.each do |segment|
if (line =~ /#{segment}/)
temp_file.puts line
end
end
end
t.close()
temp_file.close()
end
目前,它只保存位于数组filter
中的最后一个运行字符串,并将其保存到temp_file
。看起来循环不会运行数组中的所有字符串,或者不会全部保存它们。我在文本文件Filtered_text.txt
中放置了五个字符串。它只会将我最后匹配的行打印到temp_file
。
答案 0 :(得分:4)
这个(未经测试的代码)将复制原始代码,只是更简洁和惯用:
filter = Regexp.union(File.open('C:\Ruby193\scripts\Filtered_text.txt').readlines.map(&:chomp))
File.open('C:\Ruby193\scripts\PARSED_TRIAL.txt', 'a+') do |temp_file|
File.foreach('C:\Ruby193\scripts\TRIAL_output_log.txt') do |l|
temp_file.puts l if (l[filter])
end
end
让您了解正在发生的事情:
Regexp.union(%w[a b c])
=> /a|b|c/
这为您提供了一个正则表达式,它将遍历字符串以查找任何子字符串匹配项。这是一个区分大小写的搜索。
如果要关闭这些漏洞,请使用以下内容:
Regexp.new(
'\b' + Regexp.union(
File.open('C:\Ruby193\scripts\Filtered_text.txt').readlines.map(&:chomp)
).source + '\b',
Regexp::IGNORECASE
)
,使用与上面相同的样本输入数组将导致:
/\ba|b|c\b/i