草庐IT

哈希环

全部标签

ruby - 从哈希中删除 key 的非破坏性方法

是否有从哈希中删除键值对的非破坏性方法?例如,如果你这样做了original_hash={:foo=>:bar}new_hash=original_hashnew_hash=new_hash.reject{|key,_|key==:foo}或original_hash={:foo=>:bar}new_hash=original_hashnew_hash=new_hash.dupnew_hash.delete(:foo)然后original_hash没有改变,new_hash改变了,但是它们有点冗长。但是,如果你这样做了original_hash={:foo=>:bar}new_hash

ruby - Ruby 程序的持久哈希表?

我的Ruby脚本需要一个小型非结构化数据库。不是Sqlite,更像是持久哈希表的东西可以完美地工作,只要它可以存储基本的Ruby结构(数组、字符串、哈希等-都是可序列化的)并且不会在Ruby脚本崩溃时被破坏。我知道有很多类似Perl和Tie::Hash的解决方案,所以可能有一些类似Ruby的gem。那会是什么gem?编辑:据我所知,PStore和yaml解决方案是基于每次更改时读取、解码、重新编码和写入整个数据库。这不仅需要所有这些都适合内存,而且是O(n^2)。所以它们似乎都不是特别好的解决方案。 最佳答案 有PStore在Rub

ruby-on-rails - 如何在 Ruby 中使用 HMAC 模块创建 MD5 哈希?

使用Google+Bing并没有给出应该是一个简单问题的答案:您应该如何使用Ruby中的HMAC模块来创建带MD5的HMAC(使用secret)?HMAC文档看起来非常薄。谢谢! 最佳答案 这应该是最简单的方法:OpenSSL::HMAC.digest(OpenSSL::Digest::Digest.new('md5'),secret_key,your_data) 关于ruby-on-rails-如何在Ruby中使用HMAC模块创建MD5哈希?,我们在StackOverflow上找到一个

Ruby,基于多个字段的数组中的唯一哈希

我想取回基于运动和类型组合的哈希值数组我有以下数组:[{sport:"football",type:11,other_key:5},{sport:"football",type:12,othey_key:100},{sport:"football",type:11,othey_key:700},{sport:"basketball",type:11,othey_key:200},{sport:"basketball",type:11,othey_key:500}]我想回去:[{sport:"football",type:11,other_key:5},{sport:"football"

ruby - 迭代哈希集合

{"Journal"=>[[4,-785.0],[13,-21.9165000915527],[14,-213.008995056152],[15,-50.074499130249]]}你如何在Ruby中迭代这个散列,你将如何分离键和值? 最佳答案 Ruby有一个统一的迭代接口(interface)。Ruby中的所有集合都有一个名为each的方法,它允许您迭代集合中的每个元素。但是请注意,显式迭代是一种代码味道。您应该主要使用高级迭代器,例如map、reduce、select、find、reject等等。在这个集合是Hash的特殊情

ruby - 在 ruby​​ 哈希中搜索空值

我有一个像这样的ruby散列h={"a"=>"1","b"=>"","c"=>"2"}现在我有一个ruby​​函数,它计算这个散列,如果它找到一个空值的键则返回true。我有以下函数,它即使哈希中的所有键都不为空也始终返回truedefhash_has_blank(hsh)hsh.eachdo|k,v|ifv.empty?returntrueendendreturnfalseend我在这里做错了什么? 最佳答案 试试这个:defhash_has_blankhshhsh.values.any?&:empty?end或者:defhash

ruby - 在 Ruby 中动态创建多维哈希

我是一名PHP开发人员,正在努力精通Ruby。我现在正在努力的项目之一是一个源代码审计工具,它可以扫描webapp文件以寻找多种网络编程语言中的潜在危险功能。找到匹配项后,脚本会将相关信息保存在poi(兴趣点)类中,以便稍后显示。该类的示例实例看起来像这样(在YAML中建模):poi:file_type:"php"file:"the-scanned-file.php"line_number:100match:"eval()"snippet:"echoeval()"在展示中,我想像这样组织这些兴趣点:-file_type--file---match(thesearchedpayload)

ruby - Ruby 中不一致的隐式哈希创建?

好的,所以我将我自己的DSL中的一些东西与Ruby进行了比较。他们都支持的一个结构是这个x=["key"=>"value"]知道数组和散列的区别,我会认为这是不合法的,但是在Ruby中的结果是[{"key"=>"value"}]这是为什么?有了这种语法,你为什么不能这样做x=("key"=>"value")为什么数组是隐式创建的哈希的特例? 最佳答案 另一个特殊情况是在函数调用中,考虑:deff(x)puts"OK:#{x.inspect}"endf("foo"=>"bar")=>OK:{"foo"=>"bar"}因此在某些情况下,

ruby - 调用 ObjectSpace.count_objects 时哈希键的含义是什么?

在Ruby1.9(YARV)中,您可以获得所有当前已分配对象的计数,如下所示:ObjectSpace.count_objects它返回一个像这样的散列{:TOTAL=>1226560,:FREE=>244204,:T_OBJECT=>26141,:T_CLASS=>9819,:T_MODULE=>1420,:T_FLOAT=>287,:T_STRING=>260476,:T_REGEXP=>4081,:T_ARRAY=>72269,:T_HASH=>14923,:T_STRUCT=>4601,:T_BIGNUM=>7,:T_FILE=>16,:T_DATA=>54553,:T_MATC

ruby - 如何将哈希对象传递给 HAML 标记

请考虑这个例子:-user_links_params=_user_link_params(current_user)%a{:'data-msgstore-path'=>user_links_params[:'data-msgstore-path'],:'data-user_id'=>user_links_params[:'data-user_id'],:class=>user_links_params[:class],}/toomanyhtmltagsandstufftofitinasimplelink_to我很乐意将所有这些都放在一个简单的语句中,如下所示:%a[_user_link