首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Ruby解析数组(特殊情况)

Ruby解析数组(特殊情况)
EN

Stack Overflow用户
提问于 2013-04-25 06:07:28
回答 1查看 92关注 0票数 2

我正在执行一个查询,并以数组(MySql2类型对象)的形式从数据库中获取以下数据:

代码语言:javascript
复制
 +-----------+---------------+---------------+------+------+---------------+
 | build     | platform_type | category_name | pass | fail | indeterminate |
 +-----------+---------------+---------------+------+------+---------------+
 | 10.0.1.50 | 8k            | UMTS          |   10 |    2 |             5 |   
 | 10.0.1.50 | 8k            | UMTS          |   10 |    2 |             5 | 
 | 10.0.1.50 | 8k            | IP            |   10 |    2 |             5 | 
 | 10.0.1.50 | 8k            | IP            |   14 |    1 |             3 | 
 | 10.0.1.50 | 9k            | IP            |   14 |    1 |             3 | 
 | 10.0.1.50 | 9k            | IP            |   12 |    1 |             1 | 
 | 10.0.1.50 | 9k            | UMTS          |   12 |    1 |             1 | 
 | 10.0.1.50 | 9k            | UMTS          |   12 |    1 |             1 | 
 | 10.0.1.50 | 9k            | UMTS          |   12 |    1 |             1 | 
 | 10.0.1.50 | 9k            | Stability     |    9 |    4 |             0 | 
 | 10.0.1.50 | 9k            | Stability     |   15 |    1 |             0 | 

我想将它显示在我的UI中的一个表中,如下所示:

代码语言:javascript
复制
 +-----------+---------------+---------------+------+------+---------------+
 | build     | platform_type | category_name | pass | fail | indeterminate |
 +-----------+---------------+---------------+------+------+---------------+
 |           |               | UMTS          |   20 |    4 |            10 |
 |           | 8k            |---------------------------------------------|
 |           |               | IP            |   24 |    3 |             8 |
 |           |---------------|---------------------------------------------|
 | 10.0.1.50 |               | IP            |   26 |    2 |             4 |
 |           |               |---------------------------------------------|
 |           | 9k            | UMTS          |   36 |    3 |             3 |
 |           |               |---------------------------------------------|
 |           |               | Stability     |   24 |    5 |             0 |
 ---------------------------------------------------------------------------

我确实尝试过使用hash来为构建找到唯一的平台类型。但由于我是ruby的新手,我在正确使用散列时遇到了问题。如果有人能帮我解析一下这些数据,我将不胜感激。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-04-25 06:55:13

假设您有一个数组数组:

代码语言:javascript
复制
@data = sql_results.group_by(&:first).map do |b, bl|   
  [b, bl.group_by(&:second).map{|p, pl| [p, pl.map{|r| r[2..-1]}] }.sort_by(&:first)]
end.sort_by(&:first)

以下是如何分解逻辑的方法。

  • 按第一列对行进行分组。这将返回一个散列,其中key作为第一个列名,value作为行数组。
  • 按第二列(平台类型)对每个构建列表进行分组。每个组都应包含从3到最后一列的COL值数组。
  • 按平台类型对平台列表进行排序
  • 按生成名称

对生成列表进行排序

生成的结构如下所示:

代码语言:javascript
复制
[
  [
    "10.0.1.50", [
      [
        "8k", [
          ["UMTS", 20, 4, 10],
          ["IP", 24, 3, 8]
        ]
      ], 
      [
        "9k", [
          ["IP", 26, 2, 4],
          ["UMTS", 36, 3, 3],
          ["UMTS", 24, 5, 0]
        ]
      ]
    ]
  ]
]

您可以在视图布局示例中使用以下内容:

代码语言:javascript
复制
%table
  %tr
    - %w(build platform_type category_name pass fail indeterminate).each do |name|
      %th=name
  - @data.each do |build, build_list|
    %tr
      %td=build
      %td{:colspan=4}
        %table
          - build_list.each do |build, platform_list|
            %tr
              %td=build
              %td{:colspan=3}
                %table
                  - platform_list.each do |row|
                    %tr
                      - row.each do |attr|
                        %td=attr

如果您使用AR模型,请执行以下操作:

代码语言:javascript
复制
class  Build < ActiveRecord::Base

  def self.builds_by_platform
    reply = Hash.new{|h, k| h[k] = Hash.new{|h, k| h[k] = []}}
    Build.order("build ASC, platform_type ASC").find_each do |row|
      reply[row.build][row.platform_type] << row
    end
    reply.map{|b, bh| [b, bh.sort_by(&:first)}.sort_by(&:first)
  end

end

在您的控制器中,您可以访问规范化变量,如下所示:

代码语言:javascript
复制
@report _list = Build.builds_by_platform

您可以使用@report _list变量来呈现表格。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16203057

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档