1

我们如何实现“就地”转换为散列值的浮点数?动机是不必像这样编写一堆代码

r['delivery_fee'] = r['delivery_fee'].to_f
r['delivery_free_over'] = r['delivery_free_over'].to_f
r['delivery_possible_over'] = r['delivery_possible_over'].to_f
r['delivery_range'] = r['delivery_range'].to_f

反而

to_f r['delivery_fee']
to_f r['delivery_free_over']
# ...

我这样做了,但它没有按预期的方式工作。

def to_f(s)
  s = s.to_f
end

data = "1"
p data # => "1"
to_f data
p data # => Still "1" and not float
4

3 回答 3

5

这很简单:

h = { one: '1', two: '2' }

Hash[h.keys.zip(h.values.map(&:to_f))]
# => { :one => 1.0, :two => 2.0 }

# or

Hash[h.map {|k, v| [k, v.to_f] }]
# => { :one => 1.0, :two => 2.0 }

使用这两者中的哪一个是一个偏好问题,真的。

于 2013-01-21T01:53:35.883 回答
3

你不能做你想做的,因为你不能改变变量引用的对象。您只能操纵对象。您不能将String对象更改为Float; 您只能生成从字符串派生的新浮点数。

但是您可以减少代码的重复性:

%w{delivery_fee delivery_free_over delivery_possible_over delivery_range}.each do |k|
  r[k] = r[k].to_f
end
于 2013-01-21T00:56:10.273 回答
2

正如 dbenhur 所说,您需要更改哈希,而不是 a 的结果字符串hash[key]

h = {:key => 'value'}
def to_f(h, key)
  h[key] = h[key].to_f
end
to_f(h, :key)
# => 0.0
h
# => {:key=>0.0}
于 2013-01-21T00:56:19.357 回答