草庐IT

php - 我需要不寻常的排序 mysql 结果

全部标签

Ruby:排序哈希数组,即使键可能不存在

在Rails应用程序中,我有一个哈希数组,我可以轻松地对其进行排序array_of_hashes.sort_by{|hash|hash[:key_to_sort]}但是如果不是每个数组成员都有一个键:key_to_sort怎么办?然后排序将失败“String与nil的比较失败”。有没有办法让排序继续?或者还有其他方法吗? 最佳答案 这取决于您在散列没有排序键时要执行的操作。我可以想象两种情况:1)从排序中排除散列arr.delete_if{|h|h[:key_to_sort].nil?}.sort_by{|h|h[:key_to_s

ruby - 为什么一些 Ruby 方法需要 bang 而其他方法不需要是破坏性方法?

例如,array.pop不需要bang来永久改变数组。为什么会这样,在没有这种一致性的情况下开发这些特定的Ruby方法背后的原因是什么? 最佳答案 Bang方法最常用于区分同一方法的危险版本和安全版本。以下是一些示例情况,人们可能想用bang/no-bang组合来区分:mutator方法-一个版本更改对象,另一个版本返回一个副本并保持原始对象不变遇到错误时,一个版本抛出异常,而另一个版本只将错误消息写入日志或什么都不做但是,如果只有一个版本有意义,则惯例是取消爆炸。例如,弹出数组而不实际更改它是没有意义的。在这种情况下,它最终会变成

ruby-on-rails - 如何在 Rails 4 中通过 hstore 属性对结果进行排序?

如何通过hstore属性对查询结果进行排序?@items=Item.includes(:product).order('products.properties@>hstore("platform")')原因PG::Error:ERROR:column"platform"doesnotexistLINE1:...oduct_id"ORDERBYproducts.properties@>hstore("platform"...platform是一个hstore键,存放在properties列中,是一个hstore类型。 最佳答案 双引号

ruby - Rails 3 不需要的 html 转义

我正在将我的胖Rails2应用程序转换为在Rails3上运行。在与一大群bug和我的老板大喊大叫之后进行了长时间的激烈斗争,页面全部呈现为转义的html字符串。所以所有的div、图像等都是为用户编写的。出于某种原因,这个局部调用呈现了一个转义字符串'something_really_interesting'%>作为所有RubyonRails应用程序,这条指令很少被调用!那么我将如何处理所有这些调用而不是作为转义字符串正常呈现? 最佳答案 使用在部分文件中。http://github.com/rails/rails/blob/3270

ruby - 需要在 Ruby 中进行前向声明

我正在尝试在一个文件中编写一个Ruby脚本。我想知道是否可以在开头编写“main”函数,然后定义main使用的其他函数。换句话说,我想调用一个尚未定义的函数,使它们不依赖于定义顺序。仅仅改变顺序是不可能的,因为它会给出一个“未定义的方法”错误。在C/C++中,我们使用前向声明...在Ruby中是否有类似的东西或其他解决方案? 最佳答案 您只需要在main函数运行时定义您调用的函数,而不是在定义时定义。因此,最简单的解决方案是在脚本的开头编写main函数,但在结尾调用它。defmainfoo(42)bar(24)end#definit

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-on-rails - 给定有序的 id 列表对对象数组进行排序

我有一组对象@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

ruby - ruby 是否有一个列表类型可以在添加/删除时保持内容排序?

我需要一个Ruby中的数据结构,在添加或删除元素时保持其元素排序,并允许(至少)能够从列表中弹出第一个元素。我在ruby​​文档中找到的最接近的是SortedSet.但是,这似乎没有提供任何方式来通过索引访问元素(甚至弹出第一个元素)这些是我需要的具体操作:将对象添加到列表从列表中弹出第一个对象检查一个对象是否在列表中从列表中删除对象(按对象,而不是按索引)ruby是否为此内置了任何东西,或者是否有任何我可以获取的库可以提供给我?我可以毫不费力地实现一个,但如果可能的话,我宁愿使用一个已经存在的。目前我使用的是Ruby1.8,但切换到1.9可能没问题。编辑:由于似乎有些困惑,我需要的排

arrays - Ruby:sum 与 inject(:+) 产生不同的结果

我注意到array.sum和array.inject(:+)产生不同的结果。这是什么原因?a=[10,1.1,6.16]a.inject(:+)#=>17.259999999999998a.sum#=>17.26 最佳答案 Array#sum的C实现委托(delegate)给Kahansummationalgorithm当它的一些输入是float时。这个算法......significantlyreducesthenumericalerrorinthetotalobtainedbyaddingasequenceoffinitepre

.net - 为什么异步 I/O 需要事件循环

我在C#/.Net中做了很多开发,异步故事从第一天起就一直存在(诚然,多年来API从开始/结束到事件发生了显着变化,到Task和async/await).在过去一年左右的时间里,我一直在使用Node.js进行开发,它异步执行所有I/O并使用单线程事件循环模型。最近我在做一个我们使用Ruby的项目,对于应用程序的一部分,我觉得异步地发出一大堆Web请求是有意义的,并且惊讶地发现Ruby中的异步故事是巨大的不同的。执行任何异步I/O的唯一方法是使用EventMachine。我的问题归结为:为什么在.Net中(据我所知,Java/JVM也是如此)不需要事件循环,而且我可以触发异步请求在任何时