草庐IT

提取分区

全部标签

ruby-on-rails - 如何从用户数组中提取电子邮件

如果我执行User.all.pluck(:email)那么它工作正常。但如果我这样做arr=Array.newarr=User.all然后arr.pluck(:email)这是引发以下错误undefinedmethod`pluck'for#这意味着我不能将pluck与数组一起使用,那么我们如何才能像上面那样仅在一行中从一组记录中获取特定字段值。我不想遍历数组中的每条记录。 最佳答案 pluck可用于执行极简数据库查询。当你有一个数组时,只需使用map:arr.map(&:email) 关

ruby-on-rails - 在 Nokogiri 中获取属性值以提取链接 URL

我有一个看起来像这样的文档:link我无法让Nokogiri为我获取href属性的值。我想将地址作为字符串存储在Ruby变量中。 最佳答案 html=linkHTMLdoc=Nokogiri::HTML(html)doc.xpath('//div/a/@href')#=>[#]或者如果您想更具体地了解div:>>doc.xpath('//div[@id="block"]/a/@href')=>[#]>>doc.xpath('//div[@id="block"]/a/@href').first.value=>"http://googl

ruby-on-rails - Ruby:从字符串中提取单词

我正在尝试从字符串中解析单词并将它们放入数组中。我试过以下方法:@string1="orienteddesign,decomposition,encapsulation,andtesting.Uses"puts@string1.scan(/\s([^\,\.\s]*)/)它似乎可以解决问题,但它有点不稳定(例如,我应该包括更多特殊字符)。在ruby中有更好的方法吗?可选:我有一个CS类(class)描述。我打算把里面的所有单词都提取出来放在一个字符串数组中,从生成的数组中去掉英语中最常见的单词,然后把剩下的单词作为标签,用户可以用来搜索cs类(class)。

从 URL 字符串中提取主机的 Ruby 代码

我正在寻找一种方法来可靠地从Ruby中的URL字符串中提取主机名。例如http://www.mglenn.com/directory=www.mglenn.com或者http://www.mglenn.com?param=x=www.mglenn.com 最佳答案 你可以尝试这样的事情:require'uri'myUri=URI.parse('http://www.mglenn.com/directory')printmyUri.host#=>www.mglenn.com 关于从URL字

ruby-on-rails - 从 ActiveRecord 对象中提取两个属性的快捷方式?

是否有更短的方法来执行以下操作(@user.employees.map{|e|{id:e.id,name:e.name}}#=>[{id:1,name:'Pete'},{id:2,name:'Fred'}]用户has_many员工。这两个类都继承自ActiveRecord::Base。上面有两点我不喜欢它在映射之前将员工加载到内存中,它很冗长(我猜是主观的)。有没有更好的办法? 最佳答案 更新:查看@jamesharker的解决方案:从ActiveRecord>=4,pluck接受多个参数:@user.employees.pluck

ruby - 从 href html 标签中使用 ruby​​ 中的 nokogiri 提取链接(URL)?

我想从网页中提取所有URL,如何使用nokogiri做到这一点?例子:site1site2site3resultshouldbeanlist:l=['http://example.org/site/1/','http://example.org/site/2/','http://example.org/site/3/' 最佳答案 你可以这样做:doc=Nokogiri::HTML.parse(site1site2site3site4site5site6HTML_ENDl=doc.css('div.heata').map{|link|

ruby - 从 Ruby 中的字符串中提取数字

我正在使用这段代码:s=line.match(/ABCD(\d{4})/).values_at(1)[0]从字符串中提取数字,如:ABCD1234ABCD1235ABCD1236等它可以工作,但我想知道在Ruby中我还有什么其他替代方案吗?我的代码:ids=[]someBigString.lines.each{|line|ids 最佳答案 根据http://www.ruby-forum.com/topic/125709有很多Ruby方法line.scan(/\d/).join('')line.gsub(/[^0-9]/,'')lin

ruby - 如何从哈希中提取子哈希?

我有一个散列:h1={:a=>:A,:b=>:B,:c=>:C,:d=>:D}像这样提取子哈希的最佳方法是什么?h1.extract_subhash(:b,:d,:e,:f)#=>{:b=>:B,:d=>:D}h1#=>{:a=>:A,:c=>:C} 最佳答案 ActiveSupport,至少从2.3.8开始,提供了四种方便的方法:#slice、#except及其破坏性的对应方法:#slice!和#except!。其他答案中提到了它们,但将它们总结在一个地方:x={a:1,b:2,c:3,d:4}#=>{:a=>1,:b=>2,:c

ruby - 从 ruby​​ 字符串中提取最后 n 个字符

要从字符串中获取最后的n个字符,我认为您可以使用ending=string[-n..-1]但是如果字符串的长度小于n个字母,您将得到nil。有哪些解决方法?背景:字符串是纯ASCII,我可以访问ruby​​1.9.1,并且我使用的是普通旧Ruby对象(无网络框架)。 最佳答案 嗯,我能想到的最简单的解决方法是:ending=str[-n..-1]||str(编辑:or运算符的优先级低于赋值,因此请务必使用||。) 关于ruby-从ruby​​字符串中提取最后n个字符,我们在StackOv

ruby - 使用正则表达式从 Ruby 中的字符串中提取子字符串

如何从Ruby中的字符串中提取子字符串?例子:String1=""我想提取substring来自String1(即最后一次出现的和>中的所有内容)。 最佳答案 ""[/.*]*)/,1]=>"substring"不需要使用scan,如果我们只需要一个结果。当我们有Ruby的String[regexp,#]时,不需要使用Python的match。参见:http://ruby-doc.org/core/String.html#method-i-5B-5D注意:str[regexp,capture]→new_strornil