Ruby:如何在同名变量中进行乘法操作

4

我是ruby的新手。有没有办法缩短这段代码?谢谢

plans.each do |plan|
  total  = plan.landline.to_f * @landline.to_f
  total += plan.vpn.to_f * @vpn.to_f
  total += plan.other_networks.to_f * @other_networks.to_f
  total += plan.gprs.to_f * @gprs.to_f
  total += plan.sms.to_f * @sms.to_f 
  total += plan.mms.to_f * @mms.to_f
  total += plan.internat_calls_zone_1.to_f * @internat_calls_zone_1.to_f
  total += plan.internat_calls_zone_2.to_f * @internat_calls_zone_2.to_f

  if total < @total
    @total = total
    @plan_new = plan
  end
end
3个回答

7
plans.each do |plan|
  total = [ :landline, :vpn, other_networks, :gprs, :sms, :mms, :internat_calls_zone_1 ].inject(0.0) do |partial_sum, term| 
    partial_sum + plan.send(term).to_f * instance_variable_get("@#{term}").to_f
  end
  if total < @total
    @total = total
    @plan_new = plan
  end
end

3

我想你可以使用Enumerable#inject

plans.each do |plan|
  total = [:landline, :vpn, :other_networks, :gprs, :sms, :mms, :internat_calls_zone_1, :internat_calls_zone_2].inject(0) { |t, method| t + plan.send(method).to_f * @landline.send(method).to_f }
  if total < @total
    @total = total
    @plan_new = plan
  end
end

1

就我个人而言,脑海中想到的是:

plans.each do |plan|
  total = [
    :landline, :vpn, :other_networks, :gprs, :sms, :mms, 
    :internat_calls_zone_1, :internat_calls_zone_2
  ].inject(0) {|sum,key|
    sum += plan.send(key).to_f * instance_variable_get(:"@#{key}").to_f
    sum
  }

  if total < @total
    @total = total
    @plan_new = plan
  end
end

将 "incject" 更改为 "inject",并将 :"@{key}" 更改为 :"@#{key}" - rampion

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接