草庐IT

MongoDB:用MapReduce统计数组元素的重复次数

全部标签

ruby - 使用 Poltergeist 时如何获取元素的 HTML?

我正在使用带有Poltergeist驱动程序的Capybara。我的问题是:如何获取节点的HTML(字符串)?我读到过使用RackTest驱动程序你可以像这样得到它:find("table").native#=>nativeNokogirielementfind("table").native.to_html#=>"..."但是Poltergeist在节点上调用#native会返回Capybara::Poltergeist::Node,而不是原生的Nokogiri元素。然后在Capybara::Poltergeist::Node上再次调用#native再次返回相同的Capybara::

ruby - 使用 Nokogiri 插入和删除 XML 节点和元素

我想提取XML文件的一部分,并记下我提取了该文件中的某些部分,例如“这里提取了一些东西”。我正尝试用Nokogiri来做这件事,但似乎并没有真正记录如何:删除的所有child更改inner_text那个完整的元素有什么线索吗? 最佳答案 Nokogiri让这一切变得非常简单。使用thisdocument例如,以下代码将找到所有vitamins标签,删除它们的子标签(以及子标签的子标签等),并将它们的内部文本更改为“Childrenremoved”。require'nokogiri'io=File.open('sample.xml',

ruby-on-rails - Ruby On Rails 应用程序中的重复任务 : Cron or other?

我目前正在编写一个从RSS源中提取新信息的应用程序,并且必须以一定的频率更新这些RSS源。目前我只在用户请求提要时拉取,但我想将该行为更改为自动定期获取。我正在编写一个与数据库交互并通过cron定期启动的shellscript-但这是很多双重努力,所以我想知道执行此操作的“RailsWay”或“RubyWay”是什么。我正在使用Ubuntu、Apache和Passenger。您能否建议甚至可能包含在应用程序中的更好的方法,这样我就可以轻松地将应用程序部署到另一台机器上,而不必与cron混在一起? 最佳答案 我建议做一些类似rake任

ruby - 循环 ruby 的简单计数器

对于ruby​​.times,是否有一个计数器或者我是否必须执行以下操作count=04.timesdoputs"thisisthecount#{count}"count=count+1 最佳答案 是的,times产生一个计数器:4.timesdo|count|puts"thisisthecount#{count}"end 关于ruby-循环ruby的简单计数器,我们在StackOverflow上找到一个类似的问题: https://stackoverflow

ruby - 如何在不重复缩进代码的情况下在 HAML 中执行 if/else

根据用户是否登录,我想打印不同类型的%body-tag。我目前是这样做的:-ifdefined?@user%body(data-account="#{@user.account}")%h1Welcome-#allmycontent-else%body%h1Welcome-#allmycontent如您所见,其中有很多重复代码。我怎样才能消除这个?我已经尝试过以下方法:-ifdefined?@user%body(data-account="#{@user.account}")-else%body%h1Welcome-#allmycontent不幸的是,这不起作用,因为HAML将其解释为好

ruby-on-rails - Ruby/RoR - 计算数组中元素的出现次数

我有一个哈希{1=>true,7=>false,6=>true,4=>false}或者像这样的数组[1,true],[7,false],[6,true],[4,false]]或[真、假、真、假]。如何找到数组中true的个数? 最佳答案 为了对元素进行计数,您显然必须遍历集合。由于遍历Hash会产生两个元素的Array,因此前两个实际上完全相同:{1=>true,7=>false,6=>true,4=>false}.count(&:last)[[1,true],[7,false],[6,true],[4,false]].count(

ruby - 从嵌套哈希中删除特定元素

我正在尝试使用嵌套哈希。我有一副纸牌,如下所示:deck_of_cards={:hearts=>{:two=>2,:three=>3,:four=>4,:five=>5,:six=>6,:seven=>7,:eight=>8,:nine=>9,:ten=>10,:jack=>10,:queen=>10,:king=>10,:ace=>11},:spades=>{:two=>2,:three=>3,:four=>4,:five=>5,:six=>6,:seven=>7,:eight=>8,:nine=>9,:ten=>10,:jack=>10,:queen=>10,:king=>10,:

ruby-on-rails - 计算数组元素之间的差异

给定一个由n个整数组成的有序数组,如下所示:ary=[3,5,6,9,14]我需要计算数组中每个元素与下一个元素之间的差异。使用上面的例子,我最终会得到:[2,1,3,5]起始数组中可能有0个、1个或多个元素,我要处理的数字会大得多(我将使用纪元时间戳)。我尝试了以下方法:times=@messages.map{|m|m.created_at.to_i}left=times[1..times.length-1]right=times[0..times.length-2]differences=left.zip(right).map{|x|x[0]-x[1]}但我上面的解决方案既不是最优

Ruby - 查找两个数组不相同的元素

我一直在思考以下问题-有两个数组,我需要找到它们不常见的元素,例如:a=[1,2,3,4]b=[1,2,4]预期的答案是[3]。到目前为止,我一直这样做:a.select{|elem|!b.include?(elem)}但它给了我O(N**2)时间复杂度。我相信它可以更快地完成;)此外,我一直在考虑以这种方式获取它(使用一些与&相反的方法,它给出了2个数组的公共(public)元素):a!&b#=>doesn'tworkofcourse另一种方法可能是将两个数组相加并使用类似于uniq的方法找到唯一元素,这样:[1,1,2,2,3,4,4].some_method#=>wouldret

ruby - Rails 中的字数统计?

假设我有一个带有标题和正文的博客模型。如何显示正文中的字数和标题中的字符数?我希望输出是这样的标题:洛伦正文:LoremLoremLorem这篇文章的字数是3。 最佳答案 "LoremLoremLorem".scan(/\w+/).size=>3更新:如果你需要将rock-and-roll作为一个词来匹配,你可以这样做"LoremLoremLoremrock-and-roll".scan(/[\w-]+/).size=>4 关于ruby-Rails中的字数统计?,我们在StackOver