草庐IT

MongoDB 文本搜索和排序依据

全部标签

ruby-on-rails - sunspot solr 按多个术语搜索

我正在使用sunspot_railsgem,我正在尝试进行如下搜索:搜索名称为Mary或Sally的用户但我不知道如何做或。如果我做类似的事情:search=Users.searchdofulltext'MarySally'end或search=Users.searchdofulltext'Mary'fulltext'Sally'end我没有得到任何结果......但是如果我做其中一个,而不是两个,我会得到预期的结果:search=Users.searchdofulltext'Mary'#orfulltext'Sally'end将返回单个项目。对于太阳黑子,这甚至可能吗?-------

ruby-on-rails - 在 rails 4 中实现通用搜索

我有一个带有多个模型和View页面的Rails4应用程序。我的应用程序的应用程序布局包含一个搜索栏。但它目前处于非事件状态。搜索栏的目的是让用户在所有模型中搜索输入的关键字,基本上使其成为全局搜索。有没有通用搜索的gem?或者它必须通过sql查询手动完成?我可以看到在其View页面上实现对特定模型的搜索的方法。但我希望它一次搜索所有模型。我该怎么办? 最佳答案 我认为在您的情况下最好的方法是使用ElasticSearch。提供了一个简洁的集成gemhere.该页面上提供了指向文档的链接。

ruby - ruby 和 irb 使用不同的模块搜索路径吗?

我有一个试图需要restclient模块的Ruby脚本。当我将它减少到只有这一行时,它仍然失败:#!/usr/bin/envrubyrequire'restclient'当我运行它时,出现以下错误:./test.rb:3:in`require':nosuchfiletoload--restclient(LoadError)from./test2.rb:3当我运行irb时,模块加载正常:$irb>>require"restclient"=>true>>据我所知,脚本和irb似乎都具有相同的模块路径:$ruby-e"puts$:"/Library/Ruby/Site/1.8/Library

ruby-on-rails - 如何按散列值在 JSON 散列数组中进行搜索?

我正在使用Postgres的JSON数据类型来存储一些信息。例如,我有一个模型User,它有一个字段locations,它包含一个json文档(包含键和值对的对象数组),格式如下:[{"name":"Location1",kind:"house"},{"name":"Location2",kind:"house"},{"name":"Location3",kind:"office"},...{"name":"LocationX",kind:"house"}]我想用.where查询JSON数据类型。我想查询至少有一个位置为kind=office的用户。谢谢!

ruby - 从 Ruby 中的排序数组创建嵌套哈希——递归 group_by

我有一个对象数组,这些对象已根据这些对象的几个属性进行了排序。按照优先顺序,这些属性是foo、bar和baz。这意味着对象首先按foo排序;然后具有相同foo值的子序列按bar排序;然后具有相同foo和bar值的那些按baz排序。我想将其转换为反射(reflect)该分组的嵌套哈希。基本上我正在寻找递归Enumerable#group_by。键是foo、bar和baz的值;这些值将是对象的子哈希或数组。这是一个例子:[obj1,obj2,...objn].group_by_recursive(:foo,:bar,:baz)#=>{foo_val_1=>{bar_val_1=>{baz_

ruby-on-rails - 在 Ruby on Rails 中根据频率对数组进行排序

我有一个嵌套的数字数组,排列如下:ids=[[5,8,10],[8,7,25],[15,30,32],[10,8,7]]我只需要一个包含所有键的数组,无需重复,所以我使用了这个:ids=ids.flatten.uniq产生这个:ids=[5,8,10,7,25,15,30,32]由于我使用了.uniq,它消除了重复值。但是,我想根据它们在子数组中出现的频率来对值进行排序,而不是它们碰巧处于的顺序——所以像这样:ids=[8,10,7,5,25,15,30,32] 最佳答案 应该这样做:ids.flatten.group_by{|i|

ruby-on-rails - 如何从 Rails 发送纯文本而不是 HTML 电子邮件?

我想从Rails应用程序发送纯文本电子邮件。在我的邮件发送配置中,我有:ActionMailer::Base.default_content_type='text/plain'尽管如此,当我从Rails控制台发送测试电子邮件时,我得到:>>GeneralAppMailer.deliver_test#...Content-Type:text/html;charset=utf-8在Gmail中查看它,它似乎确实是作为HTML处理的。 最佳答案 确保您的模板以.text.erb扩展名结尾,而不是.html.erb。参见ActionMail

ruby-on-rails - Rails 在我的纯文本电子邮件中转义 HTML

我正在使用rails3.2.5ActionMailer发送纯文本邮件。鉴于我有这样的邮件View:message_from_user.text.erb:Hi,Yougotthefollowingmessagefrom:当@message是"quotes&ersands",那么纯文本邮件包含"quotes&ampersands".所以看起来rails只是将其视为HTMLView并转义任何html以防止跨站点脚本。然而,这是一封纯文本邮件。分机号是.text.erb和ActionMailer检测到这一点并将MIME设置为text/plain.所以我从不想转

ruby - 有没有办法在不将整个文件加载到数组中的情况下搜索文件?

这个有效:f=File.new("myfile").readlinesf[0]#=>"line1"f[21]#=>"line22"但是如果我有一个非常大的文件,并且只需要读取几行怎么办?是否可以在不将文件加载到数组的情况下查找特定行并在Ruby中读取它们?我理解IO流,其中(就像在stdin的情况下)您不能随机搜索流。当然,必须有一种方法可以在不加载整个文件的情况下执行此操作。 最佳答案 不要忽略IO类。IO::foreach是返回枚举器的方法之一,可以延迟计算。IO#each_line也是将返回枚举器的另一个。在Ruby2.0中,

ruby - 在 ruby​​ 中创建文件数组并按日期排序

我有一个文件名数组,有什么方法可以按修改日期对这些文件进行排序吗? 最佳答案 您可以将sort_by方法与File.mtime方法结合使用,它返回给定文件的最后修改时间。filenames.sort_by{|filename|File.mtime(filename)} 关于ruby-在ruby​​中创建文件数组并按日期排序,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/47509