我有一个INPUT文件,其中包含以下内容:
123\n
456\n
789
我想像这样运行我的脚本:script.rb< INPUT并将它转换为INPUT文件的内容到一个数组,拆分新的行字符。所以,我有像myArray = [123,456,789]这样的东西。这是我试图做的事情并没有太多运气:
myArray = STDIN.to_s
myArray.split(/\n/)
puts field.size
我期待这打印3,但我得到15.我真的很困惑。有什么指针吗?
答案 0 :(得分:21)
你想要
myArray = $stdin.readlines
这将把所有$ stdin放入一个数组中,每行输入一个数组项。
请注意,使用大量输入文件时效率非常低(内存方面),因此使用以下内容会更好:
$stdin.each_line do |l|
...
end
而不是
a = $stdin.readlines
a.each do |l|
...
end
因为前者没有预先为所有事情分配内存。尝试以第二种方式处理数GB的日志文件,以了解系统的交换性能有多好......< grin>
答案 1 :(得分:1)
使用 $stdin
代替$ stdin.to_s
ruby -e 'p $stdin.readlines.size' < INPUT
3
ruby -e 'p $stdin.to_s'
"#<IO:0x7fc7cc578af0>"
答案 2 :(得分:1)
STDIN.lines是懒惰的,但是给你一个类似于数组的结构来传递并迭代。