Ruby数组到索引哈希?

问题描述 投票:10回答:2

我经常发现自己在Ruby中建立查找表,通常是为了缓存一些昂贵的计算或构建要传递给视图的内容。我认为对此必须有一个简短易懂的习语,但我们想不出一个。例如,假设我要以

开始
[65, 66, 67, ...]

并结束于

{65 => "A", 66 => "B", 67 => "C", ...}

我们可以想到的不够漂亮的习语包括:

array = (65..90).to_a

array.inject({}) {|hash, key| hash[key]=key.chr; hash}
{}.tap {|hash| array.each {|key| hash[key] = key.chr}}
Hash[array.zip(array.map{|key| key.chr})]

但是所有这些都有些痛苦:难以阅读,容易弄乱,意图不清晰。当然,Ruby(或一些Rails助手)对此具有一些不错的魔力吗?

ruby-on-rails ruby
2个回答
23
投票

关于

 Hash[(65..90).map { |i| [i, i.chr] }]

我认为这是显而易见的,也是不言而喻的。而且,我没有一种更简单的方法来解决这个相当具体的任务,不幸的是,Ruby没有可与Python中的dict理解相提并论的东西。如果需要,可以使用Facets宝石,其中包括以下内容:

require 'facets'
(65..90).mash { |i| [i, i.chr] }

0
投票

我认为从Ruby 2.1开始,最惯用的方法是使用.to_h,因为它可以像这样在块上调用:

(65..90).map { |i| [i, i.chr] }.to_h
© www.soinside.com 2019 - 2024. All rights reserved.