草庐IT

Java可恢复哈希计算

全部标签

ruby-on-rails - 如何计算数组中具有特定属性值的项目?

在我的应用程序中,我有一个名为@apps的数组,它由ActiveRecord加载,其中包含包含应用程序名称、环境等的记录。我目前正在使用@apps.count获取数组中的应用程序数量,但我无法计算数组中environment=0.我尝试了@apps.count(0)但没有成功,因为每条记录都有多个字段。我也试过类似@apps.count{|environment|environment=0}但什么也没发生。有什么建议吗? 最佳答案 只需使用select来缩小您想要的范围:@apps.select{|a|a.environment==

ruby - 在 ruby​​ 中对 JSON 哈希数组进行排序

所以我有一个哈希数组:[{"id":"30","name":"Dave"},{"id":"57","name":"Mike"},{"id":"9","name":"Kevin"},...{"id":"1","name":"Steve"}]我想按id属性对其进行排序,使其看起来像这样:[{"id":"1","name":"Steve"},{"id":"2","name":"Walter"},...{"id":"60","name":"Chester"}]我假设我使用的是sort_by方法,但我不确定该怎么做。 最佳答案 这应该有效:a

ruby - 将 ruby​​ 源代码从旧样式转换为新样式哈希

有人知道一个转换器,它采用ruby​​源文件列表并可靠地将所有旧式(hash-rocket)哈希替换为新式(ruby1.9)哈希语法吗?:) 最佳答案 Rubocop是一个静态代码分析器,可以根据Ruby风格指南的许多建议评估您的代码。它有一个--auto-correct选项,可以自动将您的代码更改为推荐的代码。这些自动更正选项之一是hashsyntax.示例:rubocop--onlyHashSyntax--auto-correct只会更正您的哈希值。 关于ruby-将ruby​​源代

ruby - 在 Ruby 中,为什么 nil[1]=1 的计算结果为 nil?

例如:nil[1]#=>NoMethodErrornil[1]=1#=>nil这不仅仅是语法,它也发生在变量上:a=nila[1]#=>NoMethodErrora[1]=1#=>nil奇怪的是:nil.method(:[]=)#=>NameError[].method(:[]=)#=>#ruby2.3.0p0 最佳答案 一些随机发现:[仅在Ruby2.3.0p0中]方法好像不存在:nil.method(:[]=)#=>NameError:undefinedmethod`[]='nil.respond_to?(:[]=)#=>fal

ruby - 在 JRuby 中,如何确定导致 java.lang.ThreadDeath 的原因?

在为一些与JRuby中的临时文件交互的代码运行单元测试时,我有时会得到以下信息:Exception:java.lang.ThreadDeaththrownfromtheUncaughtExceptionHandlerinthread"Thread-6395"它似乎没有引起任何问题,但这是怎么回事,我如何确定它发生在哪里?我尝试打开-d,但这并没有给我异常的堆栈跟踪。 最佳答案 FWIW:这可能与http://jira.codehaus.org/browse/JRUBY-7074有关.我偶尔会在不使用反引号但调用系统的JRuby程序中

ruby - 如何比较 RSpec 中的两个哈希值?

我有两个散列h1和h2我想在RSpec中进行比较。我想检查h1的元素在一些转换后是否与h2相同,我们称之为f。也就是说,我想验证对于h1中的每个键k,h1[k]==f(h2[k])。例如,如果h2中的所有值都是h1中相应值的两倍,那么我想检查每个键k在h1中,h2[k]==h1[k]*2。在RSpec中执行此操作的正确方法是什么?目前我这样做:h1=...expect(h2.all?{|k,v|v==f(h1[k])}).tobetrue但这看起来很笨重。 最佳答案 听起来您正在测试的是转换。我会考虑写这样的东西:it"transf

ruby - 计算具有特定子集大小的集合分区

给定一个包含n个元素的集合,我需要找到该集合的所有分区,其中有k个大小几乎相等的子集。例如,对于一个有7个元素和3个子集的集合,我只想要分区,其中有两个子集,每个子​​集有2个元素,一个子集有3个元素。我不想要一个包含1、2和4个元素的子集的分区。换句话说,有877possiblepartitions对于一组7个元素,但我只对由2/2/3个元素组成的子集组成的105个(?)分区感兴趣:实际上n大约是35,这意味着大约有2.81*1027个分区,“仅”8,338,573,669,964,101partitionswiththreesubsets.因此,我不可能将它们全部计算出来并费力地找

Ruby 相当于 perl 的 "Data::Dumper",用于打印深度嵌套的哈希/数组

这不是RubyequivalentofPerlData::Dumper的副本.这个问题已经超过3.5年了,因此想检查从那时起Ruby中是否有任何可用的新选项。我正在寻找perl的Dumper在ruby​​中的等价物。我不在乎Dumper在幕后做了什么。我已经广泛使用它在perl中打印深度嵌套的哈希和数组。到目前为止,我还没有在ruby​​中找到替代品(或者我可能没有找到一种方法来充分利用Ruby中的可用替代品)。这是我的perl代码及其输出:#!/usr/bin/perl-wusestrict;useData::Dumper;my$hash;$hash->{what}->{where}

ruby - 在 Ruby 中对哈希数组的值求和

我在想出添加哈希数组的优雅方法时遇到了麻烦[{:a=>1,:b=>2,:c=>3},{:a=>1,:b=>2,:c=>3},{:a=>1,:b=>2,:c=>3}]应该返回[{:a=>3,:b=>6,:c=>9}]我知道它可能会涉及映射/归约,但我想不出正确的语法,ruby-docdotorg与我的版本不匹配也无济于事我使用的是1.8.7 最佳答案 array.inject{|x,y|x.merge(y){|_,a,b|a+b}}(在Ruby1.8.7上验证) 关于ruby-在Ruby中

ruby - Ruby 中的双向哈希表

我需要一个Ruby中的双向哈希表。例如:h={:abc=>123,:xyz=>789,:qaz=>789,:wsx=>[888,999]}h.fetch(:xyz)#=>789h.rfetch(123)#=>abch.rfetch(789)#=>[:xyz,:qaz]h.rfetch(888)#=>:wsxrfetch方法意味着反向获取,这只是我的建议。注意三件事:如果多个键映射到相同的值,则rfetch返回所有键,打包在数组中。如果值是一个数组,则rfetch在数组的元素中查找它的参数。双向哈希意味着fetch和rfetch都应该在恒定时间内执行。Ruby中是否存在这样的结构(包括外