我有一个方法可以从我的表中选择所有行,如下所示:
smtp_status_raw = my_table.select(:message, :is_valid, :hostname).map { |h| h.values }
这会返回一个如下所示的数组:
[{:message=>"blah", :is_valid=>true, :hostname=>"1"}, {:message=>"blah", :is_valid=>true, :hostname=>"2"}, {:message=>"blah", :is_valid=>true, :hostname=>"3}]
使用上述信息,我想创建一个如下所示的哈希:
{
:node_status =>
{
{:hostname => "1", :message: "blah"},
{:hostname => "2", :message: "blah"},
{:hostname => "3", :message: "blah"}
}
}
首先,我的问题 - 是否有可能像上面那样创建一个哈希?在上面的示例Sequel查询中,我有三个对象,它们是三个独立的主机,我想将这三个主机添加到:node_status
密钥中。那可能吗?如果那不是有效的哈希,那么另一种选择是什么呢?
其次,这是我尝试过的:
# Initialize the hash
smtp_status_hash = { :node_status: => nil }
我已使用smtp_status_hash
键初始化node_status
哈希,但我不确定如何嵌套查询结果。
答案 0 :(得分:5)
这不是有效的哈希,因为你有3个值,但:node_status
子哈希中没有键。你可以这样做:
smtp_status_raw = [
{:message=>"blah", :is_valid=>true, :hostname=>"1"},
{:message=>"blah", :is_valid=>true, :hostname=>"2"},
{:message=>"blah", :is_valid=>true, :hostname=>"3"}
]
{
node_status: smtp_status_raw.collect do |hash|
hash.reject { |key, value| key == :is_valid }
end
}
将:node_status
中的值作为数组获取:
{
:node_status=>[
{:message=>"blah", :hostname=>"1"},
{:message=>"blah", :hostname=>"2"},
{:message=>"blah", :hostname=>"3"}
]
}
或者你可以这样做:
{
node_status: smtp_status_raw.collect do |hash|
[hash[:hostname], hash[:message]]
end.to_h
}
设置子哈希,key
为:hostname
,value
为:message
:
{
:node_status=>{
"1"=>"blah",
"2"=>"blah",
"3"=>"blah"
}
}
或者如果您想要保留更多密钥:
{
node_status: smtp_status_raw.collect do |hash|
[hash[:hostname], hash.reject { |key, value| key == :is_valid }]
end.to_h
}
仍然是一个散列,其中key
是:hostname
但value
有另一个散列:
{
:node_status=>{
"1"=>{:message=>"blah", :hostname=>"1"},
"2"=>{:message=>"blah", :hostname=>"2"},
"3"=>{:message=>"blah", :hostname=>"3"}
}
}
要在创建Hash
后设置密钥的值,您可以执行以下操作:
smtp_status_hash = { node_status: nil }
smtp_status_hash[:node_status] = "Whatever you want here"
您可以详细了解Hash
及其方法,以及如何select
和reject
保留或删除哈希中的密钥。哈希虽然是字典结构,但必须始终包含key
和单value
,但该值可能是Array
或其他Hash
。
答案 1 :(得分:0)
试试这个
smtp_status_hash = {:node_status=>[]}; my_table.select(:message, :is_valid, :hostname).map{ |h| h.values }.each{|i| smtp_status_hash[:node_status] << (i)}