首页 > 代码库 > ruby逐行遍历文件
ruby逐行遍历文件
ruby遍历文件内容,基本思路是逐行读取逐行打印,也是比较普遍的方法:
#!/usr/bin/env ruby #Encoding:utf8 file = File.open("/tmp/abc.txt") file.each_line do |line| print line end file.close
另外一种写法,一次性读取一次性打印,相对耗费更多内存,小文件场合比上面的方法更快。不推荐操作大文件。
#!/usr/bin/env ruby # Encoding:utf8 wholefile = File.read("/tmp/abc.txt") print wholefile
小结
1、第一种方法比较像sed,awk之类的流编辑器,第二种方法跟cat一样暴力。
2、File.read不需要显式关闭文件句柄。
扩展
在打开文件前,判断文件是否存在
#!/usr/bin/env ruby # Encoding: utf8 if File.exist?("/tmp/abc.txt") file = File.open("/tmp/abc.txt") file.each_line do |line| print line end file.close else puts "error:file not exist" end
逐行读取,将文件名作为ruby脚本的参数
#!/usr/bin/env ruby # Encoding: utf8 filename = ARGV[0] if File.exist?(filename) file = File.open(filename) file.each_line do |line| print line end file.close else puts "error:file not exist" end
本文出自 “专注Linux 运维” 博客,转载请与作者联系!
ruby逐行遍历文件
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。