我有一个匹配的哈希数组。
me = [{paid: true, setup: true, send_to: "somewhere"},
{paid: true, setup: false, send_to: "somewhere else"},
{paid: false, setup: true, send_to: "somewhere new"},
{paid: false, setup: false, send_to: "somewhere outside"}]
我有一个只有 2 个键/值对的哈希:
went = {paid: true, setup: false}
我想做的是将went
与me
进行比较,如果有匹配项,则返回send_to
几乎像include?
但这不起作用,因为我的went
哈希只有 2 个键/值对。
有这样的事情吗?
me.find { |item| item[:paid] == went[:paid] && item[:setup] == went[:setup] }&.fetch(:send_to)
或者这个
me.find { |item| item.values_at(:paid, :setup) == went.values_at(:paid, :setup) }&.fetch(:send_to)
不对键进行硬编码的方法:
me.find { |item| went <= item }&.fetch(:send_to)
me.find { |item| item >= went }&.fetch(:send_to)
me.find(&went.method(:<=))&.fetch(:send_to)
me.find { |item| item.values_at(*went.keys) == went.values }&.fetch(:send_to)
me.find { |item| went.to_a & item.to_a == went.to_a }&.fetch(:send_to)
me.find { |item| item.merge(went) == item }&.fetch(:send_to)
我最喜欢前两个。最后一个来自此页面,它显示了子集/超集运算符的一些历史记录。
me.find { |h| h == h.merge(went) }&.[](:send_to)
#=> "somewhere else"
me.find { |h| h == h.merge({:paid=>true, :setup=>"cat"}) }&.[](:send_to)
#=> nil