0

以下代码中缺少一些内容。

hostnames =  []
ip_addrs  =  []
hw_addrs  =  []

File.open("/etc/dhcp/dhcpd.conf", "r").each_line do |line|

  unless line.match('#')                        # Make sure the line is not commented
    if line.match("host-name")
        hostname = line.scan(/"([^"]*)"/)       # extract the Hostname
    elsif line.match("fixed-address")
        ip_addr = line.scan(/(\S*);/)           # Extract IP addr
    elsif line.match("ethernet")
      hw_addr = line.scan(/(\S*);/)             # Extract the HW address
    end
  end

  hostnames + hostname.to_a if hostname         # Protect against `nil' values
  ip_addrs  + ip_addr.to_a  if ip_addr          #  Same
  hw_addrs  + hw_addr.to_a  if hw_addr          #  Same

end

puts hostnames.inspect                          # Should be a list of hostnames...

这应该使用文件中找到的值填充数组dhcpd.conf。如果我打印File.open.each_line块内的值,那么我会得到 STDOUT 的完整列表。当我尝试获取块之外的值时,我得到空数组。

我认为该块会生成我的变量的副本并对其进行处理,但它们不会从块中传回。我不确定内部是如何工作的,只是一个猜测。

4

2 回答 2

1

更改hostnames + hostname.to_ahostnames << hostname.to_a

在您的代码的当前版本中,您实际上并没有将 添加hostnamehostnames数组中。<<hostname元素推到hostnames

于 2013-08-07T19:31:49.353 回答
1

如果要向数组中添加某些内容,则需要使用正确的运算符:

hostnames += hostname.to_a if hostname

您正在做的是创建一个临时结果并丢弃它:a + b不是永久修改,而是a = a + b简写在哪里a += b

通常,您使用<<将单个元素添加到数组中,它避免创建新数组而只是追加到现有数组。例如:

hostnames << hostname if hostname

这通常就足够了。除非您实际上一次附加多个值,否则将所有内容转换为数组只是为了连接它们是浪费的。

于 2013-08-07T19:29:13.197 回答