rubino uno di rinforzo per creare hash
Ieri, mentre sta attraversando uno dei miei vecchi programmi, ho trovato questo scritto da me qualche volta indietro:
#begin magic
hash=Hash[*CGI.unescape(raw_text).split('&').map{|x| b=x.split("=");b.push(nil) if b.size==1;b}.flatten]
#end magic
Per uccidere un po di suspense lasciatemi rivelare che raw_text assomiglia
, Diritto che è stato tagliato dal riconoscimento di pagamento paypal.
Di sopra della linea in caso di rottura in più parti si legge:
unescaped_array = CGI.unescape (raw_text). dividere ('&') unescaped_array unescaped_array.collect = {| x | b = x.split ("="); b.push (zero) se b.size == 1, b} flattened_array = unescaped_array.flatten hash = Hash [* flattened_array]
Facciamo singole fasi IRB:
irb (main):. 009:0> unescaped_array = CGI.unescape (raw_text) diviso ('&') => ["SUCCESSO", "mc_gross = 10,00" "protection_eligibility = non ammissibili", "payer_id U7PPJJ4TSJ47E =" "imposta = 0,00", "payment_date = 09:45:30 10 Lug 2009 PDT", "payment_status = In attesa "] irb (main): 013:0> unescaped_array unescaped_array.map = {| x | b = x.split ("="); b.push (zero) se b.size == 1, b} => [["SUCCESSO", nil], ["mc_gross", "10.00 protection_eligibility "],["", "non ammissibili"], ["payer_id", "U7PPJJ4TSJ47E"], ["tassa", "0.00"] , ["payment_date", "09:45:30 10 luglio 2009 PDT"], ["payment_status", "In attesa"]] irb (main): 014:0> flattened_array = unescaped_array.flatten => ["SUCCESSO", nil, "mc_gross", "10.00", "protection_eligibility", "non ammissibili", "payer_id", "U7PPJJ4TSJ47E", "fiscale", "0.00", "payment_date", "09:45: 30 10 Luglio 2009 PDT "," payment_status "," In attesa "] irb (main): 015:0> hash = Hash [* flattened_array] => {"Tassa" => "0.00", "payment_status" => "In attesa", "payer_id" => "U7PPJJ4TSJ47E", "mc_gross" => "10.00", "SUCCESSO" => nil, "payment_date" = > "09:45:30 10 Lug 2009 PDT", "protection_eligibility" => "non ammissibili"}
BTW, * si chiama operatore splat in rubino
Un altro modo per creare hash da 'matrice di coppie' è quello di utilizzare iniettare:
hash = [[1,2], [3,4]] iniettare risultato ({}){|, elemento | risultato [element.first] = risultato [element.last];. risultato} C'è un modo più
Scrivere un ciclo, che lascio come esercizio per i lettori!
Ecco un caso po uso indipendenti di creare hash di array:
irb (main): 005:0> [1,2,3,4,7,9] group_by {| x | x <5.? : Minore:: maggiore} => {: Minore => [1, 2, 3, 4],: maggiore => [7, 9]}
Si può fare più cose, fondamentalmente frutto del blocco viene utilizzato come chiave per tale elemento nella hash risultante.



































