在Ruby中读取文件的常用方法是什么?
例如,这是一种方法:
fileObj = File.new($fileName, "r")
while (line = fileObj.gets)
puts(line)
end
fileObj.close
Run Code Online (Sandbox Code Playgroud)
我知道Ruby非常灵活.每种方法的好处/缺点是什么?
我试图使用以下代码从文件中读取行.但是在阅读文件时,内容都在一行中:
line_num=0
File.open('xxx.txt').each do |line|
print "#{line_num += 1} #{line}"
end
Run Code Online (Sandbox Code Playgroud)
但是这个文件分别打印每一行.
我必须使用stdin,比如ruby my_prog.rb < file.txt,我不能假设文件使用的行尾字符是什么.我该怎么处理?
我正在寻找一个脚本来搜索模式的文件(或文件列表),如果找到,则用给定的值替换该模式.
思考?
我试图在给定文件夹中搜索给定类型的所有文件(例如.pdf)并将它们复制到新文件夹.我需要做的是指定一个根文件夹,并在该文件夹及其所有子文件夹中搜索与给定类型(.pdf)匹配的任何文件.任何人都可以告诉我如何搜索根文件夹的子文件夹及其子文件夹等.这听起来像一个递归方法可以解决这个问题,但我无法正确实现一个?(顺便说一下,我正在ruby中实现这个程序).
Ruby中是否有内置函数可以在不使用任何循环的情况下读取整个文件?到目前为止,我只遇到了以块(行或字符)读取的方法.
我正在处理大量数据文件(每个数百万行).
在开始处理之前,我想得到文件中行数的计数,然后我可以指出处理的距离.
由于文件的大小,将整个文件读入内存是不切实际的,只计算有多少行.有没有人对如何做到这一点有一个很好的建议?
有没有一种在Ruby中读取,编辑和编写文件的好方法?
在我的在线搜索中,我发现了一些建议将其全部读入数组的内容,修改所述数组,然后将所有内容写出来.我觉得应该有一个更好的解决方案,特别是如果我正在处理一个非常大的文件.
就像是:
myfile = File.open("path/to/file.txt", "r+")
myfile.each do |line|
myfile.replace_puts('blah') if line =~ /myregex/
end
myfile.close
Run Code Online (Sandbox Code Playgroud)
当replace_puts将当前行上书写,而不是(上)写的下一行,因为它目前确实因为指针位于线(分离后)结束.
那么匹配的每一行/myregex/都会被'blah'取代.显然我想到的是涉及到的更多,就处理而言,并且将在一行中完成,但想法是一样的 - 我想逐行读取文件,并编辑某些行,以及我完成后写出来.
也许有一种方法可以说"倒回到最后一个分隔符之后"?或者each_with_index通过线索引号使用和写入某种方式?但是,我找不到任何类似的东西.
到目前为止,我所拥有的最佳解决方案是按顺序读取内容,将它们逐行写入新的(临时)文件(可能已编辑),然后使用新的临时文件覆盖旧文件并删除.同样,我觉得应该有更好的方法 - 我认为我不应该创建一个新的1gig文件只是为了编辑现有1GB文件中的某些行.
所以我在这里找到了这个问题,但我遇到输出问题以及如何用if语句处理它.这就是我所拥有的,但它总是说即使文件中不存在文字监视器也是如此
if File.readlines("testfile.txt").grep(/monitor/)
do something
end
Run Code Online (Sandbox Code Playgroud)
它应该是=="nil"吗?我对ruby很新,不知道输出会是什么.