草庐IT

CREATED_BY

全部标签

ruby-on-rails - rails - 使用 Group_by 时 - 如何获取索引?

我有以下内容:sets=DataSet.all.group_by{|data|[data.project_id,"-",data.thread_id].join("")}:LastPost问题是我需要一个索引。所以我更新了上面的内容::LastPost然后中断,出现错误:undefinedmethod`last'for0:Fixnum想法?谢谢 最佳答案 您观察到的问题是因为参数分配给block的方式。在您的第二个示例中,您将观察到range包含一个包含单个range和匹配的datas的数组,datas变量包含索引,i始终为nil。

ruby-on-rails - rails : Sorting a query by params?

我正在使用运行一个简单的查找全部并使用willpaginate分页,但我也希望由用户对查询进行排序。想到的第一个解决方案就是使用params[:sort]http://localhost:3000/posts/?sort=created_at+DESC@posts=Post.paginate:page=>params[:page],:order=>params[:sort]但他的方法的问题是查询默认为按ID排序,我希望它是created_at。这是一种安全的排序方法吗?有没有办法默认使用created_at? 最佳答案 我会使用命名

ruby - sort 和 sort_by 之间的细微差别

这不是一个技巧问题:[1,2,3].sort_by{|x,y|xy}=>[1,2,3][1,2,3].sort_by{|x,y|yx}=>[1,2,3]这是怎么回事?我原以为数组会彼此相反(因为它们具有排序和相同的参数)。 最佳答案 #sort_by应该只采用一个block参数,数组中的一项,并根据block的结果进行排序。当向它传递两个block参数时,第二个设置为nil因此所有block结果都像1nil这是nil所以数组的顺序不变。[1,3,2].sort_by{|x|x}#sortsusingxy=>[1,2,3][1,3,2

ruby-on-rails - 如何按 created_at 属性对集合进行排序

我正在使用RubyonRails2.3.8,我有一个从其他两个集合构建的集合,如下所示:@coll1=Model1.all@coll2=Model2.all@coll=@coll1现在,我想按子孙顺序按created_at属性对该集合进行排序。所以,我做了以下事情:@sorted_coll=@coll.sort{|a,b|b.created_ata.created_at}我有以下异常:undefinedmethod`created_at'for#甚至认为它存在于那些模型中。谁能帮帮我吗? 最佳答案 您将另一个数组作为另一个元素插入@

ruby - `sort_by' : comparison of Array with Array failed (no nil data)

classCustomSorterattr_accessor:start_date,:availabledefinitialize(start_date,available)@start_date=Time.mktime(*start_date.split('-'))@available=availableendendcs1=CustomSorter.new('2015-08-01',2)cs2=CustomSorter.new('2015-08-02',1)cs3=CustomSorter.new('2016-01-01',1)cs4=CustomSorter.new('2015-0

ruby-on-rails - 在 Rails 中添加 created_at DESC 功能

我有一个带有帖子和评论模型的应用程序。在我的索引操作/View中,我遍历帖子并从最近创建时间到最早创建时间显示它们。我的评论嵌套在我的帖子中,因此在我的帖子显示操作/View中,我想遍历评论并让它们显示从最近创建到最早创建的时间。如果我在我的post.rb文件中创建一个方法,我似乎只能让它工作。我有这个:post.rb:defnewest_commentsself.comments.order("created_atDESC")end在我的帖子展示View中,我可以遍历帖子评论并且效果很好:但我想在Controller层设置此功能,但我不知道如何设置。这是我在我的帖子Controlle

ruby-on-rails - 点击 Google Contacts API 时出现 "connection reset by peer"错误

我正在尝试使用GoogleContactsAPI将GoogleContacts拉入Rails应用程序。我已经完成了Oauth2握手,现在正在使用我的访问token请求protected资源。这是代码:uri=URI('https://www.google.com/m8/feeds/contacts/default/full')params={:client_id=>APP_CONFIG[:google_api_client_id],:access_token=>auth.access_token,"max-results".to_sym=>max_results}uri.query=U

ruby-on-rails - rails 3 : User Created custom forms?

我正在努力思考如何允许用户创建具有所有字段类型的自定义表单。如果有一颗gem就好了,但我似乎无法在任何地方找到。所以我有一个像这样的数据库设置:t.integer:form_idt.string:namet.string:hintt.integer:positiont.string:field_typet.boolean:requiredt.integer:sizet.boolean:multiplet.text:valuest.timestamps这就是我所在的位置。我想不出如何遍历field_type并返回值,以及将它们与实际填写的表单相关联。谢谢 最佳

arrays - Enumerable 的 group_by 是否保留 Enumerable 的顺序?

是否Enumerable#group_by保留每个值内的原始顺序?当我得到这个时:[1,2,3,4,5].group_by{|i|i%2}#=>{1=>[1,3,5],0=>[2,4]}是否保证,例如,数组[1,3,5]包含此顺序的元素,而不是,例如[3,1,5]?有没有关于这一点的说明?我没有提到键1和0之间的顺序。那是一个不同的问题。 最佳答案 是的,Enumerable#group_by保留输入顺序。这是该方法在MRI中的实现,来自https://github.com/ruby/ruby/blob/trunk/enum.c:s

ruby-on-rails - find_or_initialize_by 不适用于 2 列

我正在尝试使用ActiveRecord在我的数据库中插入数据。当我使用pdays=MyModel.new而不是下面的find_or_initialize_by进行初始化时,脚本运行良好。但它只运行一次。我需要它每天运行以执行更新。当我第二次尝试使用pdays=MyModel.new运行脚本时,没有出现重复键约束。因此,我正在尝试使用以下带有2个参数的find_or_initialize_by,但这给出了一个错误:undefinedmethod`find_or_initialize_by'2列一起构成唯一记录:vertica_traffic.eachdo|vdays|pdays=MyMo