草庐IT

Mongodb 和聚合框架。对数组元素求和以对文档元素求和

全部标签

ruby - 如何使用单个字符串键访问散列的嵌套元素?

我在和Ruby玩,基本上我有@trans={:links=>{:quick_notes=>"aaaaaaa"}}我想调用类似的东西deft#...somethingendt('links.quick_notes')访问trans[:links][:quick_notes]我基本上是在尝试实现与使用国际化时相同的功能I18n.t('something.other.foo')到目前为止我想出了这个方法deft(key)a=''key.to_s.split('.').each{|key|a+="[:#{key}]"}#nowa=="[:links][:quick_notes]"#butIca

ruby - 使用 mongodb/mongoid 运行时更改模型

我必须在mongoid模型中添加几个字段,我知道MongoDB没有迁移,但如果我继续而不删除数据库,使rails完全“重新生成”数据库,它不会显示或使用新的领域!去这里最好的方法是什么?有比删除/重新打开mongodb更软的东西吗?提前致谢卢卡 最佳答案 一般来说,应该可以在运行时用新字段更新旧文档。MongoDB中不需要迁移。您可能想编写rake任务以使用新字段和默认值更新旧文档。您可以通过检查那些默认值为nil的新字段来找到这些文档。更新简单风格:如果您使用默认值定义一个新字段,只要您设置了一个新值,就应该始终使用该值:应用程序

ruby - 安装 RDoc 文档时出错 : incompatible encoding regexp match

上周,在一些gem安装或gem更新操作中,我收到了与这些类似的错误:ERROR:Whilegeneratingdocumentationforsinatra-1.3.1...MESSAGE:errorgeneratingC:/RailsInstaller/Ruby1.9.2/lib/ruby/gems/1.9.1/doc/sinatra-1.3.1/rdoc/README_de_rdoc.html:incompatibleencodingregexpmatch(UTF-8regexpwithIBM437string)(Encoding::CompatibilityError)类似的:E

ruby-on-rails - 如何改进用 `' ` 引用所有数组元素并返回包含所有这些引用和逗号分隔元素的字符串的代码?

我正在使用Rails3.2.2,我想用'引用所有数组元素并返回一个包含所有这些引用和逗号分隔元素的字符串。这时候我在用['a','b','c'].collect{|x|"'#{x}'"}.join(",")#=>"'a','b','c'"但我认为我可以改进上面的代码(也许通过使用一个我不知道的Ruby方法,如果它存在的话)。可能吗? 最佳答案 我用"'#{%w{abc}.join("','")}'"这里是扩展版:'#Startingquote%w{abc}.join("','")#Joinarraywith','delimitert

ruby-on-rails - 我如何从 Ruby 代码连接到 mongodb?

我如何从Ruby代码连接到mongodb? 最佳答案 首先,您必须安装MongoDbgem:geminstallmongo然后运行代码:require'rubygems'#notnecessaryforRuby1.9require'mongo'db=Mongo::Connection.new.db("mydb")#ORdb=Mongo::Connection.new("localhost").db("mydb")#ORdb=Mongo::Connection.new("localhost",27017).db("mydb")

ruby - 如何检测元素是否存在于 Watir 中

我对Watir比较陌生,但找不到有关如何检查元素是否存在的良好文档(示例)。当然有API规范,但如果我找不到示例,这些对我来说意义不大。我已经尝试了这两种组合,但似乎没有任何效果......如果browser.image(:src"/media/images/icons/reviewertools/editreview.jpg").exists然后...如果browser.image(:src"/media/images/icons/reviewertools/editreview.jpg").存在?那么……如果有人对如何实现这个有具体的建议,请帮忙!谢谢!

ruby - 将元素插入 ruby​​ Hash 中的数组

在Ruby中,为了创建数组的散列并将元素推送到这些数组,我见过两种习惯用法。我想知道人们更喜欢哪一个,为什么。(披露:我有自己的看法,但我想确保我没有遗漏一些明显的东西。)方法1:使用Hash的花式初始化器:ht=Hash.new{|h,k|h[k]=[]}ht["cats"]当您使用尚不存在的键访问ht时,此方法会创建一个空数组。方法2:简单的初始化器,花哨的访问器:ht={}(ht["cats"]||=[])人们对哪一个更好(或者哪一个优于另一个)有意见吗? 最佳答案 有时散列最初是用数据填充的,后来它只用于检索数据。在那些情况

ruby - MongoDB:无法从 BSON 类型 EOO 转换为 Date

我正在尝试使用聚合框架(使用ruby​​)并像这样投影日期:db['requests'].aggregate([{"$project"=>{_id:0,method:'$method',user:'$user',year:{'$year'=>'$timestamp'}}}])文档是这样的:{_id:ObjectId("5177d7d7df26358289da7dfd"),timestamp:ISODate("2013-04-12T03:58:05+00:00"),method:"POST",status:"200",inputsize:"874",outputsize:"4981",u

Ruby 相当于 Python 的 "array[i:]"选择 i 之后的所有数组元素?

我发现自己想要类似Python的东西ary=[1,2,3,4,5,6,7,8]ary[2:]#=>[3,4,5,6,7,8]这些天所有的时间。解决方案最终总是多行且丑陋。我想知道最优雅的解决方案可能是什么,因为我的不值得展示。 最佳答案 使用Array#drop2.1.0:019>ary.drop(2)=>[3,4,5,6,7,8] 关于Ruby相当于Python的"array[i:]"选择i之后的所有数组元素?,我们在StackOverflow上找到一个类似的问题:

ruby - 从哈希值的 ruby​​ 数组中获取前 n 个元素

嘿,我有一个数组,其中每个元素都是一个包含一些值和一个计数的散列。result=[{"count"=>3,"name"=>"user1"},{"count"=>10,"name"=>"user2"},{"count"=>10,"user3"},{"count"=>2,"user4"}]我可以按如下方式对数组进行排序:result=result.sort_bydo|r|r["count"]end现在我希望能够根据计数检索前n个条目(而不仅仅是first(n))有没有一种优雅的方法可以做到这一点?因此,作为示例,让n=1我希望结果集为。[{"count"=>10,"name"=>"user