草庐IT

哈希环

全部标签

ruby - 如果不修改,在迭代之间保留哈希排序?

如果我遍历一次哈希,然后在不修改内容的情况下再次这样做,是否保证键以相同的顺序出现?快速测试表明:>h={'a'=>1,'b'=>2,'c'=>3}>100_000.times.map{h.to_s==h.to_s}.all?=>true另一个问题,如果允许上述情况,我可以遍历它只更改值,而不添加任何新键,并保持键的顺序不变吗?类似于这个python问题:Dodictspreserveiterationorderiftheyarenotmodified?与建议的重复项不同,我对元素是否具有完全指定的顺序不感兴趣,我只关心两次连续迭代未修改提供相同序列的限制。

ruby - 如何在 Ruby 中的哈希中初始化数组

这个问题在这里已经有了答案:Strange,unexpectedbehavior(disappearing/changingvalues)whenusingHashdefaultvalue,e.g.Hash.new([])(4个答案)关闭1年前。我正在尝试初始化一个哈希数组,例如@my_hash=Hash.new(Array.new)这样我就可以:@my_hash["hello"].push("inthestreet")=>["inthestreet"]@my_hash["hello"].push("athome")=>["inthestreet","athome"]@my_hash[

ruby - 在包含任意数量的嵌套哈希和数组的哈希中查找键/值对

Web服务正在返回包含未知数量的嵌套哈希的哈希,其中一些包含一个数组,而数组又包含未知数量的嵌套哈希。一些键不是唯一的——即存在于多个嵌套哈希中。然而,我真正关心的所有键都是唯一的。有没有什么办法可以给顶级散列一个键,即使键值对深埋在这个泥潭中也能取回它的值?(Web服务是亚马逊产品广告API,根据结果数量和每个产品类别允许的搜索类型,它提供的结果结构略有不同。) 最佳答案 这是一个简单的递归解决方案:defnested_hash_value(obj,key)ifobj.respond_to?(:key?)&&obj.key?(ke

ruby - 数组到哈希 : words count

我有一个单词数组,我想得到一个散列,其中键是单词,值是单词计数。有没有比我的更漂亮的方式:result=Hash.new(0)words.each{|word|result[word]+=1}returnresult 最佳答案 您使用的命令式方法可能是Ruby中最快的实现方式。通过一些重构,您可以编写一个单行代码:wf=Hash.new(0).tap{|h|words.each{|word|h[word]+=1}}另一种使用Enumerable#each_with_object的命令式方法:wf=words.each_with_ob

ruby - 基于值的哈希数组是唯一的

我觉得这可以改进(在ruby​​中很常见)。我正在尝试根据值对一组哈希值进行uniq。在这个例子中,我想要元素的颜色。苔藓和雪是骗子。#removeuniquearrayofhashesbasedonahashvaluea=[{:color=>"blue",:name=>"water"},{:color=>"red",:name=>"fire"},{:color=>"white",:name=>"wind"},{:color=>"green",:name=>"earth"},{:color=>"green",:name=>"moss"},{:color=>"white",:name=>

ruby-on-rails - 如何对这个哈希数组进行分组?

我有这个哈希数组:-:name:Ben:age:18-:name:David:age:19-:name:Sam:age:18我需要按年龄对它们进行分组,所以它们最终会像这样:18:-:name:Ben:age:18-:name:Sam:age:1819:-:name:David:age:19我试过这样做:array=array.group_by&:age但是我得到这个错误:NoMethodError(undefinedmethod`age'for{:name=>"Ben",:age=>18}:Hash):我做错了什么?我正在使用Rails3.0.1和Ruby1.9.2

ruby - 将 Ruby 哈希转换为 YAML

我需要将如下提供的散列转换为可读的YAML。看起来我可以为YAML::load提供一个字符串,但我想我需要先将它转换成这样的内容:hostname1.test.com:public:51private:10{"hostname1.test.com"=>{"public"=>"51","private"=>"10"},"hostname2.test.com"=>{"public"=>"192","private"=>"12"}}虽然我不确定如何有效地转换成该字符串。我查看了HASH文档,找不到任何关于to_yaml的内容。我通过搜索to_yaml找到了它,当您requireyaml时它就

ruby - 以有条件的方式构建哈希

我正在使用RubyonRails3.0.10,我想以有条件的方式构建哈希键\值对。也就是说,如果条件匹配,我想添加一个键及其相关值:hash={:key1=>value1,:key2=>value2,#Thiskey2\value2pairshouldbeaddedonly'ifcondition'is'true':key3=>value3,...}我怎样才能做到这一点并保持代码的“良好”可读性?我是否“被迫”使用merge方法? 最佳答案 我更喜欢tap,因为我认为它提供了比这里描述的解决方案更清晰的解决方案,因为它不需要对元素进

ruby-on-rails - 如何按降序对哈希值进行排序并在 ruby​​ 中输出哈希值?

output.sort_by{|k,v|v}.reverse和keyh={"a"=>1,"c"=>3,"b"=>2,"d"=>4}=>{"a"=>1,"c"=>3,"b"=>2,"d"=>4}Hash[h.sort]现在我有这两个。但我正在尝试按值降序对哈希进行排序,以便它返回=>{"d"=>4,"c"=>3,"b"=>2,"a"=>1}提前致谢。编辑:让我发布整个代码。defcount_words(str)output=Hash.new(0)sentence=str.gsub(/,/,"").gsub(/'/,"").gsub(/-/,"").downcasewords=senten

ruby - Ruby 中数组和哈希的性能

我有一个程序可以存储一个类的多个实例,比如说多达10,000个或更多。类实例有几个我不时需要的属性,但其中最重要的一个是ID。classDocumentattr_accessor:iddef==(document)document.id==self.idendend现在,存储数千个此类对象的最快方法是什么?我曾经将它们全部放入一个文档数组中:documents=Array.newdocuments现在另一种方法是将它们存储在哈希中:documents=Hash.newdoc=Document.newdocuments[doc.id]=doc#etc在我的应用程序中,我主要需要查明文档是