【问题标题】:Read a table into an array in Ruby on Rails在 Ruby on Rails 中将表读入数组
【发布时间】:2015-03-25 02:20:55
【问题描述】:

使用 RoR 4 和 SQlite3 进行开发,使用 mySQL 进行生产。

给定一个表格“事物”:

POSITION    NAME     VALUE     CODE
1           Animal   Dog       1
1           Animal   Cat       2
1           Animal   Bird      3
2           Place    USA       1
2           Place    Other     2
3           Color    Red       a
3           Color    Blue      b
3           Color    Orange    c
4           Age      Young     a
4           Age      Middle    b
4           Age      Old       c
5           Alive    Yes       y
5           Alive    No        n

如何将表格读入如下所示的数组:

a = [["1", "Animal", "Dog", "1"],
     ["1", "Animal", "Cat", "2"],
     ["1", "Animal", "Bird", "3"],
     ["2", "Place", "USA", "1"],
     ["2", "Place", "Other", "2"],
     ["3", "Color", "Red", "a"],
     ["3", "Color", "Blue", "b"],
     ["3", "Color", "Orange", "c"],
     ["4", "Age", "Young", "a"],
     ["4", "Age", "Middle", "b"],
     ["4", "Age", "Old", "c"],
     ["5", "Alive", "Yes", "y"],
     ["5", "Alive", "No", "n"]] 

【问题讨论】:

    标签: ruby-on-rails ruby arrays sorting


    【解决方案1】:

    只是:

    my_array = MyModel.select(:position, :name, :value, :code).map {|e| e.attributes.values}
    

    我认为它可以解决问题。

    已编辑

    如果你想要所有字段:

    my_array = MyModel.all.map {|e| e.attributes.values}
    

    如果你希望每一行都是一个哈希:

    my_array = MyModel.all.to_a
    

    【讨论】:

    • 完美!有没有办法允许未确定的列?例如,如果我稍后添加了一个额外的列,这段代码是否可以简单地提取所有列而不对每一列进行硬编码?
    • 这个答案解决了您的问题吗?
    【解决方案2】:

    你可以试试。

    ActiveRecord::Base.connection.execute('select * from table').map{ |row| row }
    

    【讨论】:

      猜你喜欢
      • 2015-01-10
      • 2014-08-17
      • 1970-01-01
      • 2022-11-16
      • 1970-01-01
      • 2015-05-17
      • 2013-01-21
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多