class Hash(K, V)
Overview
A Hash represents a mapping of keys to values.
See the official docs for the basics.
Included Modules
Defined in:
hash.crjson/to_json.cr
yaml/to_yaml.cr
Class Method Summary
- .new(pull : JSON::PullParser)
- .new(pull : YAML::PullParser)
- .new(default_value : V, initial_capacity = nil)
- .new(pull : YAML::PullParser, &block)
- .new(initial_capacity = nil, &block : Hash(K, V), K -> V)
- 
        .zip(ary1 : Array(K), ary2 : Array(V))
        
          Zips two arrays into a Hash, taking keys from ary1 and values from ary2.
- .new(block : Hash(K, V), K -> V | Nil = nil, initial_capacity = nil)
Instance Method Summary
- 
        #==(other : Hash)
        
          Compares with other. 
- 
        #[](key)
        
          See Hash#fetch
- 
        #[]=(key : K, value : V)
        
          Sets the value of key to the given value. 
- 
        #[]?(key)
        
          Returns the value for the key given by key. 
- 
        #all?(&block)
        
          Yields all key-value pairs to the given block, and returns true if the block returns a truthy value for all key-value pairs, else false. 
- 
        #any?(&block)
        
          Yields all key-value pairs to the given block, and returns true if the block returns a truthy value for any key-value pair, else false. 
- 
        #any?
        
          Returns true if a Hashhas any key-value pair.
- 
        #clear
        
          Empties a Hashand returns it.
- 
        #clone
        
          Similar to #dup, but duplicates the values as well.
- 
        #delete(key)
        
          Deletes the key-value pair and returns the value. 
- 
        #delete_if(&block)
        
          Deletes each key-value pair for which the given block returns true.
- 
        #dup
        
          Duplicates a Hash.
- 
        #each(&block)
        
          Calls the given block for each key-value pair and passes in the key and the value. 
- 
        #each
        
          Returns an iterator over the hash entries. 
- 
        #each_key
        
          Returns an iterator over the hash keys. 
- 
        #each_key(&block)
        
          Calls the given block for each key-value pair and passes in the key. 
- 
        #each_value
        
          Returns an iterator over the hash values. 
- 
        #each_value(&block)
        
          Calls the given block for each key-value pair and passes in the value. 
- 
        #empty?
        
          Returns truewhen hash contains no key-value pairs.
- 
        #fetch(key, &block)
        
          Returns the value for the key given by key, or when not found calls the given block with the key. 
- 
        #fetch(key)
        
          Returns the value for the key given by key. 
- 
        #fetch(key, default)
        
          Returns the value for the key given by key, or when not found the value given by default. 
- 
        #first_key
        
          Returns the first key in the hash. 
- 
        #first_key?
        
          Returns the first key if it exists, or returns nil.
- 
        #first_value
        
          Returns the first value in the hash. 
- 
        #first_value?
        
          Similar to #first_key?, but returns its value.
- 
        #has_key?(key)
        
          Returns truewhen key given by key exists, otherwisefalse.
- 
        #hash
        
          See Object#hash.
- #inspect(io : IO)
- 
        #invert
        
          Inverts keys and values. 
- 
        #key(value, &block)
        
          Returns the first key with the given value, else yields value with the given block. 
- 
        #key(value)
        
          Returns the first key with the given value, else raises KeyError.
- 
        #key?(value)
        
          Returns the first key with the given value, else nil.
- 
        #key_index(key)
        
          Returns the index of the given key, or nilwhen not found.
- 
        #keys
        
          Returns a new Arraywith all the keys.
- #merge(other : Hash(L, W), &block : K, V, W -> V | W)
- 
        #merge(other : Hash(L, W))
        
          Returns a new Hashwith the keys and values of this hash and other combined.
- #merge!(other : Hash, &block)
- 
        #merge!(other : Hash)
        
          Similar to #merge, but the receiver is modified.
- #rehash
- 
        #reject(*keys)
        
          Returns a new Hashwithout the given keys.
- 
        #reject(&block : K, V -> U)
        
          Returns a new hash consisting of entries for which the block returns false. 
- 
        #reject!(&block : K, V -> U)
        
          Equivalent to Hash#reject, but makes modification on the current object rather that returning a new one.
- #reject!(*keys)
- 
        #reject!(keys : Array | Tuple)
        
          Removes a list of keys out of hash. 
- #select(*keys)
- 
        #select(keys : Array | Tuple)
        
          Returns a new Hashwith the given keys.
- 
        #select(&block : K, V -> U)
        
          Returns a new hash consisting of entries for which the block returns true. 
- 
        #select!(&block : K, V -> U)
        
          Equivalent to Hash#selectbut makes modification on the current object rather that returning a new one.
- 
        #select!(keys : Array | Tuple)
        
          Removes every element except the given ones. 
- #select!(*keys)
- 
        #shift(&block)
        
          Deletes and returns the first key-value pair in the hash. 
- 
        #shift
        
          Deletes and returns the first key-value pair in the hash, or raises IndexErrorif the hash is empty.
- 
        #shift?
        
          Same as #shift, but returns nil if the hash is empty.
- #size : Int32
- 
        #to_a
        
          Returns a new Arrayof tuples populated with each key-value pair.
- 
        #to_h
        
          Returns self. 
- #to_json(io)
- 
        #to_s(io : IO)
        
          Converts to a String.
- #to_yaml(yaml : YAML::Generator)
- 
        #values
        
          Returns only the values as an Array.
- 
        #values_at(*indexes : K)
        
          Returns a tuple populated with the elements at the given indexes. 
Instance methods inherited from module Enumerable(T)
  
  
    
      all?all?(&block) all?, any?
any?(&block) any?, compact_map(&block) compact_map, count(item)
count(&block) count, cycle(&block)
cycle(n, &block) cycle, each(&block : T -> _) each, each_cons(count : Int, &block) each_cons, each_slice(count : Int, &block) each_slice, each_with_index(offset = 0, &block) each_with_index, each_with_object(obj, &block) each_with_object, find(if_none = nil, &block) find, first
first(count : Int) first, first? first?, flat_map(&block : T -> Array(U)) flat_map, grep(pattern) grep, group_by(&block : T -> U) group_by, in_groups_of(size : Int, filled_up_with : U = nil, &block)
in_groups_of(size : Int, filled_up_with : U = nil) in_groups_of, includes?(obj) includes?, index(obj)
index(&block) index, index_by(&block : T -> U) index_by, join(separator = "")
join(separator, io, &block)
join(separator = "", &block)
join(separator, io) join, map(&block : T -> U) map, map_with_index(&block : T, Int32 -> U) map_with_index, max max, max? max?, max_by(&block : T -> U) max_by, max_by?(&block : T -> U) max_by?, max_of(&block : T -> U) max_of, max_of?(&block : T -> U) max_of?, min min, min? min?, min_by(&block : T -> U) min_by, min_by?(&block : T -> U) min_by?, min_of(&block : T -> U) min_of, min_of?(&block : T -> U) min_of?, minmax minmax, minmax? minmax?, minmax_by(&block : T -> U) minmax_by, minmax_by?(&block : T -> U) minmax_by?, minmax_of(&block : T -> U) minmax_of, minmax_of?(&block : T -> U) minmax_of?, none?(&block)
none? none?, one?(&block) one?, partition(&block) partition, product(initial : Number, &block)
product
product(initial : Number)
product(&block) product, reduce(memo, &block)
reduce(&block) reduce, reject(&block : T -> ) reject, select(&block : T -> ) select, size size, skip(count : Int) skip, skip_while(&block) skip_while, sum
sum(initial)
sum(&block)
sum(initial, &block) sum, take_while(&block) take_while, to_a to_a, to_h to_h, to_set to_set
Instance methods inherited from class Reference
  
  
    
      ==(other)==(other : self) ==, dup dup, hash hash, inspect(io : IO) : Nil inspect, object_id : UInt64 object_id, same?(other : Reference)
same?(other : Nil) same?, to_s(io : IO) : Nil to_s
Instance methods inherited from class Object
  
  
    
      !=(other)
    !=, 
    
  
    
      !~(other)
    !~, 
    
  
    
      ==(other)
    ==, 
    
  
    
      ===(other)===(other : YAML::Any)
===(other : JSON::Any) ===, =~(other) =~, class class, crystal_type_id crystal_type_id, dup dup, hash hash, inspect(io : IO)
inspect inspect, itself itself, not_nil! not_nil!, tap(&block) tap, to_json to_json, to_pretty_json(io : IO)
to_pretty_json to_pretty_json, to_s
to_s(io : IO) to_s, to_yaml
to_yaml(io : IO) to_yaml, try(&block) try
Class methods inherited from class Object
  
  
    
      ==(other : Class)
    ==, 
    
  
    
      ===(other)
    ===, 
    
  
    
      cast(other) : self
    cast, 
    
  
    
      clone
    clone, 
    
  
    
      dup
    dup, 
    
  
    
      from_json(string_or_io, root : String) : selffrom_json(string_or_io) : self from_json, from_yaml(string : String) : self from_yaml, hash hash, inspect(io) inspect, name : String name, to_s(io) to_s, |(other : U.class) |
Class Method Detail
Zips two arrays into a Hash, taking keys from ary1 and values from ary2.
Hash.zip(["key1", "key2", "key3"], ["value1", "value2", "value3"])
# => {"key1" => "value1", "key2" => "value2", "key3" => "value3"}Instance Method Detail
Compares with other. Returns true if all key-value pairs are the same.
Sets the value of key to the given value.
h = {} of String => String
h["foo"] = "bar"
h["foo"] # => "bar"Returns the value for the key given by key.
If not found, returns nil. This ignores the default value set by Hash.new.
h = {"foo" => "bar"}
h["foo"]? # => "bar"
h["bar"]? # => nil
h = Hash(String, String).new("bar")
h["foo"]? # => nilYields all key-value pairs to the given block, and returns true if the block returns a truthy value for all key-value pairs, else false.
hash = {
  "foo":   "bar",
  "hello": "world",
}
hash.all? { |k, v| v.is_a? String } # => true
hash.all? { |k, v| v.size == 3 }    # => falseYields all key-value pairs to the given block, and returns true if the block returns a truthy value for any key-value pair, else false.
hash = {
  "foo":   "bar",
  "hello": "world",
}
hash.any? { |k, v| v.is_a? Int } # => false
hash.any? { |k, v| v.size == 3 } # => trueSimilar to #dup, but duplicates the values as well.
hash_a = {"foobar": {"foo": "bar"}}
hash_b = hash_a.clone
hash_b["foobar"]["foo"] = "baz"
hash_a # => {"foobar": {"foo": "bar"}}Deletes the key-value pair and returns the value.
h = {"foo" => "bar"}
h.delete("foo")     # => "bar"
h.fetch("foo", nil) # => nilDeletes each key-value pair for which the given block returns true.
h = {"foo" => "bar", "fob" => "baz", "bar" => "qux"}
h.delete_if { |key, value| key.starts_with?("fo") }
h # => { "bar" => "qux" }Duplicates a Hash.
hash_a = {"foo": "bar"}
hash_b = hash_a.dup
hash_b.merge!({"baz": "qux"})
hash_a # => {"foo": "bar"}Calls the given block for each key-value pair and passes in the key and the value.
h = {"foo" => "bar"}
h.each do |key, value|
  key   # => "foo"
  value # => "bar"
end
h.each do |key_and_value|
  key_and_value # => {"foo", "bar"}
endReturns an iterator over the hash entries.
Which behaves like an Iterator returning a Tuple consisting of the key and value types.
hsh = {"foo" => "bar", "baz" => "qux"}
iterator = hsh.each
entry = iterator.next
entry[0] # => "foo"
entry[1] # => "bar"
entry = iterator.next
entry[0] # => "baz"
entry[1] # => "qux"Returns an iterator over the hash keys.
Which behaves like an Iterator consisting of the key's types.
hsh = {"foo" => "bar", "baz" => "qux"}
iterator = hsh.each_key
key = iterator.next
key # => "foo"
key = iterator.next
key # => "baz"Calls the given block for each key-value pair and passes in the key.
h = {"foo" => "bar"}
h.each_key do |key|
  key # => "foo"
endReturns an iterator over the hash values.
Which behaves like an Iterator consisting of the value's types.
hsh = {"foo" => "bar", "baz" => "qux"}
iterator = hsh.each_value
value = iterator.next
value # => "bar"
value = iterator.next
value # => "qux"Calls the given block for each key-value pair and passes in the value.
h = {"foo" => "bar"}
h.each_value do |key|
  key # => "bar"
endReturns true when hash contains no key-value pairs.
h = Hash(String, String).new
h.empty? # => true
h = {"foo" => "bar"}
h.empty? # => falseReturns the value for the key given by key, or when not found calls the given block with the key.
h = {"foo" => "bar"}
h.fetch("foo") { |key| key.upcase } # => "bar"
h.fetch("bar") { |key| key.upcase } # => "BAR"Returns the value for the key given by key.
If not found, returns the default value given by Hash.new, otherwise raises KeyError.
h = {"foo" => "bar"}
h["foo"] # => "bar"
h = Hash(String, String).new("bar")
h["foo"] # => "bar"
h = Hash(String, String).new { "bar" }
h["foo"] # => "bar"
h = Hash(String, String).new
h["foo"] # raises KeyErrorReturns the value for the key given by key, or when not found the value given by default.
This ignores the default value set by Hash.new.
h = {"foo" => "bar"}
h.fetch("foo", "foo") # => "bar"
h.fetch("bar", "foo") # => "foo"Returns the first key if it exists, or returns nil.
hash = {"foo": "bar"}
hash.first_key? # => "foo"
hash.clear
hash.first_key? # => nilReturns true when key given by key exists, otherwise false.
h = {"foo" => "bar"}
h.has_key?("foo") # => true
h.has_key?("bar") # => falseInverts keys and values. If there are duplicated values, the last key becomes the new value.
{"foo": "bar"}.invert               # => {"bar": "foo"}
{"foo": "bar", "baz": "bar"}.invert # => {"bar": "baz"}Returns the first key with the given value, else yields value with the given block.
hash = {"foo" => "bar"}
hash.key("bar") { |value| value.upcase } # => "foo"
hash.key("qux") { |value| value.upcase } # => "QUX"Returns the first key with the given value, else raises KeyError.
hash = {"foo": "bar", "baz": "qux"}
hash.key("bar")    # => "foo"
hash.key("qux")    # => "baz"
hash.key("foobar") # => Missing hash key for value: foobar (KeyError)Returns the first key with the given value, else nil.
hash = {"foo": "bar", "baz": "qux"}
hash.key?("bar")    # => "foo"
hash.key?("qux")    # => "baz"
hash.key?("foobar") # => nilReturns the index of the given key, or nil when not found.
The keys are ordered based on when they were inserted.
h = {"foo" => "bar", "baz" => "qux"}
h.key_index("foo") # => 0
h.key_index("qux") # => nilReturns a new Array with all the keys.
h = {"foo" => "bar", "baz" => "bar"}
h.keys # => ["foo", "baz"]Returns a new Hash with the keys and values of this hash and other combined.
A value in other takes precedence over the one in this hash.
hash = {"foo" => "bar"}
hash.merge({"baz": "qux"})
# => {"foo" => "bar", "baz" => "qux"}
hash
# => {"foo" => "bar"}Similar to #merge, but the receiver is modified.
hash = {"foo" => "bar"}
hash.merge!({"baz": "qux"})
hash # => {"foo" => "bar", "baz" => "qux"}Returns a new Hash without the given keys.
{"a": 1, "b": 2, "c": 3, "d": 4}.reject("a", "c") # => {"b": 2, "d": 4}Returns a new hash consisting of entries for which the block returns false.
h = {"a" => 100, "b" => 200, "c" => 300}
h.reject { |k, v| k > "a" } # => {"a" => 100}
h.reject { |k, v| v < 200 } # => {"b" => 200, "c" => 300}Equivalent to Hash#reject, but makes modification on the current object rather that returning a new one. Returns nil if no changes were made.
Removes a list of keys out of hash.
h = {"a": 1, "b": 2, "c": 3, "d": 4}.reject!("a", "c")
h # => {"b": 2, "d": 4}Returns a new Hash with the given keys.
{"a": 1, "b": 2, "c": 3, "d": 4}.select("a", "c") # => {"a": 1, "c": 3}Returns a new hash consisting of entries for which the block returns true.
h = {"a" => 100, "b" => 200, "c" => 300}
h.select { |k, v| k > "a" } # => {"b" => 200, "c" => 300}
h.select { |k, v| v < 200 } # => {"a" => 100}Equivalent to Hash#select but makes modification on the current object rather that returning a new one. Returns nil if no changes were made
Removes every element except the given ones.
h = {"a": 1, "b": 2, "c": 3, "d": 4}.select!("a", "c")
h # => {"a": 1, "c": 3}Deletes and returns the first key-value pair in the hash. Yields to the given block if the hash is empty.
hash = {"foo" => "bar", "baz" => "qux"}
hash.shift { true } # => {"foo", "bar"}
hash                # => {"baz" => "qux"}
hash = {} of String => String
hash.shift { true } # => true
hash                # => {}Deletes and returns the first key-value pair in the hash,
or raises IndexError if the hash is empty.
hash = {"foo" => "bar", "baz" => "qux"}
hash.shift # => {"foo", "bar"}
hash       # => {"baz" => "qux"}
hash = {} of String => String
hash.shift # => Index out of bounds (IndexError)Same as #shift, but returns nil if the hash is empty.
hash = {"foo" => "bar", "baz" => "qux"}
hash.shift? # => {"foo", "bar"}
hash        # => {"baz" => "qux"}
hash = {} of String => String
hash.shift? # => nilReturns a new Array of tuples populated with each key-value pair.
h = {"foo" => "bar", "baz" => "qux"}
h.to_a # => [{"foo", "bar"}, {"baz", "qux}]Converts to a String.
h = {"foo": "bar"}
h.to_s       # => "{\"foo\" => \"bar\"}"
h.to_s.class # => StringReturns only the values as an Array.
h = {"foo" => "bar", "baz" => "qux"}
h.values # => ["bar", "qux"]Returns a tuple populated with the elements at the given indexes. Raises if any index is invalid.
{"a": 1, "b": 2, "c": 3, "d": 4}.values_at("a", "c") # => {1, 3}