2015-02-23 65 views
-1

所以,我猜我的疑问很简单。在Ruby中打印数组表

我有一个数组,我的目标是打印的代码的方式,因此输出以下:

Output Table

我怎样才能做到这一点?

谢谢。

+2

...什么呢你的数组看起来像?到目前为止尝试过的东西? – ptierno 2015-02-23 22:21:26

+0

为了让每个准备答案的读者不必构建包含输入数据的同一对象,请编辑以提供答案,以便他们可以复制和粘贴。例如,'arr = [{date:“2014-12-01”,来自:“Ferdous”,主题:“本周作业”},{date:“2014-12-01”,来自:“Dajana”,主题:“Keep on coding!:)”},{date:2014-12-02,来自:“麦当娜”,主题:“Re:本周作业”}]'。 – 2015-02-23 22:26:49

+1

你需要提供一些关于你的环境的更多信息(它是一个rails项目吗?这是一个'ActiveRecord'表吗?等等)和一些关于你的代码的东西(例如相关类的一个例子)以及你所做的尝试至今。 – xlembouras 2015-02-23 22:30:04

回答

2

我想有很多可以做这种宝石的,但是如果你想要滚你自己的,你可以像这样做,在一个相当普遍的方式:

你输入由列标签:

col_labels = { date: "Date", from: "From", subject: "Subject" } 

和用于行中的数据:

arr = [{date: "2014-12-01", from: "Ferdous", subject: "Homework this week"}, 
     {date: "2014-12-01", from: "Dajana", subject: "Keep on coding! :)"}, 
     {date: "2014-12-02", from: "Ariane", subject: "Re: Homework this week"}] 

其中col_labelsarr的元件具有相同的密钥。

从现在起,代码是一般的。首先构造一个散列@columns(为了方便起见,我已经创建了一个实例变量)。

@columns = col_labels.each_with_object({}) { |(col,label),h| 
    h[col] = { label: label, 
      width: [arr.map { |g| g[col].size }.max, label.size].max } } 
    # => {:date=> {:label=>"Date", :width=>10}, 
    #  :from=> {:label=>"From", :width=>7}, 
    #  :subject=> {:label=>"Subject", :width=>22}} 

def write_header 
    puts "| #{ @columns.map { |_,g| g[:label].ljust(g[:width]) }.join(' | ') } |" 
end 

def write_divider 
    puts "+-#{ @columns.map { |_,g| "-"*g[:width] }.join("-+-") }-+" 
end 

def write_line(h) 
    str = h.keys.map { |k| h[k].ljust(@columns[k][:width]) }.join(" | ") 
    puts "| #{str} |" 
end 

write_divider 
write_header 
write_divider 
arr.each { |h| write_line(h) } 
write_divider 

+------------+---------+------------------------+ 
| Date  | From | Subject    | 
+------------+---------+------------------------+ 
| 2014-12-01 | Ferdous | Homework this week  | 
| 2014-12-01 | Dajana | Keep on coding! :)  | 
| 2014-12-02 | Ariane | Re: Homework this week | 
+------------+---------+------------------------+ 

如果你想扭转显示器,使之成为大一点,像你这样的,首先执行:

$_!.reverse 
[email protected] += 4 

Output Table

+0

巨人的答案..你让Postgresql DB像输出...恭喜...... + 1 – 2015-02-24 07:02:55