在Ruby中读取文件的常见方法有哪些?
例如,这里有一个方法:
fileObj = File.new($fileName, "r")
while (line = fileObj.gets)
puts(line)
end
fileObj.close
我知道Ruby非常灵活。每种方法的优点/缺点是什么?
在Ruby中读取文件的常见方法有哪些?
例如,这里有一个方法:
fileObj = File.new($fileName, "r")
while (line = fileObj.gets)
puts(line)
end
fileObj.close
我知道Ruby非常灵活。每种方法的优点/缺点是什么?
当前回答
一个简单的方法是使用readlines:
my_array = IO.readlines('filename.txt')
输入文件中的每一行都是数组中的一个条目。该方法为您处理打开和关闭文件的操作。
其他回答
一个简单的方法是使用readlines:
my_array = IO.readlines('filename.txt')
输入文件中的每一行都是数组中的一个条目。该方法为您处理打开和关闭文件的操作。
一种更有效的方法是流,它要求操作系统内核打开一个文件,然后一点一点地从中读取字节。在Ruby中逐行读取文件时,每次从文件中获取512字节的数据,然后按“行”分割。
通过缓冲文件的内容,在将文件划分为逻辑块的同时减少了I/O调用的数量。
例子:
将这个类作为服务对象添加到应用程序中:
class MyIO
def initialize(filename)
fd = IO.sysopen(filename)
@io = IO.new(fd)
@buffer = ""
end
def each(&block)
@buffer << @io.sysread(512) until @buffer.include?($/)
line, @buffer = @buffer.split($/, 2)
block.call(line)
each(&block)
rescue EOFError
@io.close
end
end
调用它并向:each方法传递一个块:
filename = './somewhere/large-file-4gb.txt'
MyIO.new(filename).each{|x| puts x }
在这篇详细的文章中阅读:
Ruby Magic slping &流媒体文件由AppSignal
如果文件不是太长,最简单的方法是:
puts File.read(file_name)
事实上,IO。读取或文件。读取后自动关闭文件,因此不需要使用file。用木块打开。
您可以一次读取所有文件:
content = File.readlines 'file.txt'
content.each_with_index{|line, i| puts "#{i+1}: #{line}"}
当文件很大或可能很大时,通常最好逐行处理:
File.foreach( 'file.txt' ) do |line|
puts line
end
有时候你想访问文件句柄或者自己控制读取操作:
File.open( 'file.txt' ) do |f|
loop do
break if not line = f.gets
puts "#{f.lineno}: #{line}"
end
end
对于二进制文件,你可以指定一个空分隔符和块大小,如下所示:
File.open('file.bin', 'rb') do |f|
loop do
break if not buf = f.gets(nil, 80)
puts buf.unpack('H*')
end
end
最后,您可以在没有块的情况下完成,例如在同时处理多个文件时。在这种情况下,文件必须显式关闭(根据@antinome的评论改进):
begin
f = File.open 'file.txt'
while line = f.gets
puts line
end
ensure
f.close
end
参考:文件API和IO API。
File.open("my/file/path", "r") do |f|
f.each_line do |line|
puts line
end
end
# File is closed automatically at end of block
也可以像上面那样显式地关闭文件(传递一个块来打开并为你关闭它):
f = File.open("my/file/path", "r")
f.each_line do |line|
puts line
end
f.close