假设我有一个对象Person,它有has_many:foos和:bars。给定一个实例p(p=Person.new),我如何以编程方式确定可用的关系?即p.some_method=>["foo","bar"] 最佳答案 您可以使用ActiveRecordReflections(APIhere)在你的例子中:p.class.reflect_on_all_associations(:has_many).collect{|a|a.name} 关于ruby-on-rails-获取Rails中相关
有没有办法获取Bundler(这是一个Rails3)项目为当前项目加载的gem列表或路径。我正在寻找类似的东西:Gem.path但这只会返回Gemfile中Bundler主动要求的那些。 最佳答案 我要找的是这个:Gem.loaded_specs.values.map{|g|g.full_gem_path} 关于ruby-获取Bundler项目使用的gem列表,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.
arr=["red","green","blue","yellow"]arr.eachdo|colour|ifcolour=="red"colour="green"endendputsarr.inspect以上代码输出:["red","green","blue","yellow"]但为什么不呢?["green","green","blue","yellow"]我认为颜色是对数组中当前元素的引用,无论我对它做什么都会影响该数组元素? 最佳答案 当您在arr.eachblock内时,colour变量绑定(bind)到arr数组中的对象之
我的应用程序正在将以下json对象发布到Rails。[{\"completed\":false,\"id\":196,\"position\":0,\"title\":\"Item1\",\"updated_at\":\"2011-08-03T21:17:09Z\"},{\"completed\":false,\"id\":193,\"position\":1,\"title\":\"ItemX\",\"updated_at\":\"2011-08-03T21:16:19Z\"},{\"completed\":false,\"id\":197,\"position\":2,\"titl
假设我有一个整数数组:arr=[0,5,7,8,11,16]我还有另一个整数:n=6我需要一个函数来向下舍入到数组中最接近的数字:foo(n)#=>5如您所见,数字没有固定的模式。执行此操作的优雅方法是什么?谢谢 最佳答案 使用select其次是max:arr=[0,5,7,8,11,16]putsarr.select{|item|item结果:5这在线性时间内运行,不需要对数组进行排序。 关于Ruby:根据任意数字列表将数字舍入到最接近的数字,我们在StackOverflow上找到一个
我有一个日期范围(从、到),我想在不同的时间间隔(每天、每周、每月……)中循环我如何遍历这个日期范围?更新感谢您的回答,我想出了以下几点:interval='week'#month,yearstart=fromwhilestarttostop=toendlogger.debug"Intervalfrom#{start.inspect}to#{stop.inspect}"start=stop.send("beginning_of_#{interval}")start+=1.send(interval)end这将循环遍历以周、月或年为间隔的日期范围,并遵守给定间隔的开始和结束。由于我没有在
抱歉,如果这很明显,我只是不明白。如果我有一个哈希数组,例如:people=[{:name=>"Bob",:occupation=>"Builder"},{:name=>"Jim",:occupation=>"Coder"}]我想遍历数组并输出字符串,例如:“Bob:Builder”。我该怎么做?我知道如何迭代,但我还是有点迷茫。现在,我有:people.eachdo|person|person.eachdo|k,v|puts"#{v}"endend我的问题是我不明白如何返回两个值,只分别返回每个值。我错过了什么?感谢您的帮助。 最佳答案
我想随机遍历一个范围。每个值只会被访问一次,所有值最终都会被访问。例如:classArraydefshuffleret=dupj=lengthi=0whilej>1r=i+rand(j)ret[i],ret[r]=ret[r],ret[i]i+=1j-=1endretendend(0..9).to_a.shuffle.each{|x|f(x)}其中f(x)是对每个值进行操作的函数。Fisher-Yatesshuffle用于有效地提供随机排序。我的问题是shuffle需要对数组进行操作,这并不酷,因为我正在处理天文数字的大数。Ruby会快速消耗大量RAM来尝试创建一个巨大的数组。想象一下
我有一组RubyDate对象。如何找到最新的日期时间和最旧的日期时间? 最佳答案 date_array.min#=>Oldestdate_array.max#=>Mostrecent 关于ruby-从列表中获取最新和最旧的日期-Ruby,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1634971/
我有一组对象@users,每个对象都有其id属性。@users=[#,#]我还有一个有序的ids数组。ids=[2,1]¿是否有一种神奇的方法可以使用该ID列表对集合进行排序?如果可能,不再次调用数据库。谢谢!!! 最佳答案 其实你不需要排序,建立一个中间的索引散列,它是O(n):users_by_id=Hash[@users.map{|u|[u.id,u]}]users_by_id.values_at(*ids)如果您仍想尝试排序方法,Schwartziantransform就足够了:@users.sort_by{|u|ids.i