我有一个2D数组…是他们创建CSV::表的任何方式,第一行被认为是标题,并假设所有行都有相同数量的标题。
您可以使用CSV.parse
从2D数组中创建具有标题的CSV::Table
对象。
首先将2d数组转换为字符串,其中每行中的值由逗号连接,每行由换行连接,然后将该字符串与headers: true
选项一起传递给CSV.parse
require 'csv'
sample_array = [
["column1", "column2", "column3"],
["r1c1", "r1c2", "r1c3"],
["r2c1", "r2c2", "r2c3"],
["r3c1", "r3c2", "r3c3"],
]
csv_data = sample_array.map {_1.join(",")}.join("n")
table = CSV.parse(csv_data, headers: true)
p table
p table.headers
p table[0]
p table[1]
p table[2]
=比;
#<CSV::Table mode:col_or_row row_count:4>
["column1", "column2", "column3"]
#<CSV::Row "column1":"r1c1" "column2":"r1c2" "column3":"r1c3">
#<CSV::Row "column1":"r2c1" "column2":"r2c2" "column3":"r2c3">
#<CSV::Row "column1":"r3c1" "column2":"r3c2" "column3":"r3c3">
下面是用ruby创建CSV文件的基本示例:
hash = {a: [1, 2, 3], b: [4, 5, 6]}
require 'csv'
CSV.open("my_file.csv", "wb") do |csv|
csv << %w(header1 header2 header3)
hash.each_value do |array|
csv << array
end
end
@diwanshu-tyagi这将有助于解决你的问题吗?如果没有,请添加您的输入值的例子,我将更新这个答案。
感谢