Ruby 之 csv 文件读写

csv 文件写入

ruby 复制代码
require 'csv'

title = ["col1", "col2"]
contents = [["row11", "row12"], ["row21", "row22"]]

csv1 = CSV.open("test1.csv", "wb") do |csv|
  # write file title
  csv << title

  # write file body
  contents.each do |line|
    csv << line
  end
end

puts csv1.class
puts csv1.inspect

# UTF-8编码的文件,开头会加入BOM来表明编码方式
csv2 = CSV.generate("\xEF\xBB\xBF") do |csv|
    # write file title
    csv << title

    # write file body
    contents.each do |line|
      csv << line
    end
end
File.open("test2.csv", "wb"){|f| f << csv2}

puts csv2.class
puts csv2.inspect
ruby 复制代码
Array
[["row11", "row12"], ["row21", "row22"]]
String
"col1,col2\nrow11,row12\nrow21,row22\n"

csv 文件读取

ruby 复制代码
require 'csv'

csv3 = []
CSV.open("test1.csv") do |csv|
  csv.each do |line|
    csv3 << line
  end
end

puts csv3.class
puts csv3.inspect

csv4 = []
File.open("test2.csv", "rb") do |f|
  f.each do |line|
    csv4 << line
  end
end
puts csv4.class
puts csv4.inspect
ruby 复制代码
Array
[["col1", "col2"], ["row11", "row12"], ["row21", "row22"]]
Array
["\xEF\xBB\xBFcol1,col2\n", "row11,row12\n", "row21,row22\n"]
相关推荐
江东大都督周总3 天前
rabbitmq集群
javascript·rabbitmq·ruby
Hello.Reader5 天前
在 Ruby 客户端里用 ES|QL
elasticsearch·jenkins·ruby
探码科技9 天前
AI知识管理软件推荐:九大解决方案与企业应用
前端·ruby
Gavin_9159 天前
从零开始部署经典开源项目管理系统最新版redmine6-Linux Debian12
linux·ruby on rails·开源·debian·ruby·redmine
Hello.Reader9 天前
Elasticsearch Ruby 客户端安装与版本兼容指南
elasticsearch·jenkins·ruby
Gavin_9159 天前
一文速通Ruby语法
开发语言·ruby
蔡俊锋12 天前
Javar如何用RabbitMQ订单超时处理
java·python·rabbitmq·ruby
Linux运维技术栈15 天前
解决程序连不上RabbitMQ:Attempting to connect to/access to vhost虚拟主机挂了的排错与恢复
分布式·rabbitmq·ruby
臻实16 天前
Win10系统Ruby+Devkit3.4.5-1安装
开发语言·后端·ruby
skywalk816317 天前
vagrant和itamae怎么配合使用? (放弃)
运维·前端·ruby·vagrant