草庐IT

ruby - Capistrano 3.x 逐行捕获输出

在Capistrano2.x中,您可以使用以下命令逐行捕获输出run"ls-la"do|channel,stream,data|putsdataend这在Capistrano3.x中不起作用,capture和execute命令似乎不提供相同的功能。有没有办法在3.x中复制2.x的行为? 最佳答案 output=capture('cat~/file.cnf')output.each_linedo|line|putslineend这就是我使用捕获读取行的方式。如果您想捕获一行中的特定内容,您可以使用ifline.include?'use

ruby - 我如何告诉 Sinatra 它是什么环境(开发、测试、生产)?

(免责声明:在Heroku上部署Sinatra的新手。)我看过http://www.sinatrarb.com/configuration.html它告诉我set:environment,:production。我的问题是,我该如何指定它:“在Heroku中,将环境设置为生产环境,否则留在测试/开发中。”此外,即使在set:environment,:production这行之后,我也不认为它在工作,因为当我尝试在本地rackup应用程序时,它是仍在运行(当我知道(或者我认为我知道)它不应该因为我没有在我的计算机上安装postgres时)。gem文件group:productiondog

ruby-on-rails - Rails 以 JSON 格式返回所有 404 和 500 错误

我是Rails的新手,正在使用Rails4。在我的应用程序中,我想返回所有JSON格式的404和500错误{"status":404,"message":"notfound"}有一个简单的方法可以做到这一点吗?因为我只是找到了使用rails3.x执行此操作的解决方案。谢谢我正在尝试执行此解决方案NeedtoreturnJSON-formatted404errorinRails但我在故障安全响应期间收到错误:未初始化的常量ErrorsController 最佳答案 也许您正在寻找这个:render:json=>@error_objec

ruby-on-rails - 全局可用的 Gemfile

我有许多在所有Rails项目中使用的gems,但它们不是项目Gems的一部分,例如用于管理POW的powder。使用全局Gemfile管理它们对我来说很有意义,但我看不到任何示例。我应该如何管理项目gemfile中不需要的全局Gem?当我设置一台新机器等时,最好有一个安装点。我使用chruby和ruby​​-install来管理我的Ruby版本。 最佳答案 像往常一样制作一个Gemfile,并将其放在任何文件夹中。它不需要是项目文件夹。然后你可以这样做:bundleinstall--system这将在Gemfile系统范围内安装ge

ruby-on-rails - 彪马/丢失的日志

为什么我在日志中看不到任何特定于Rails的条目?我在普通的Debian机器上使用带有Nginx代理的Puma2.7.1,没什么特别的,通过RVM的ruby​​1.9.3。我的美洲狮配置:#!/usr/bin/envpumaenvironment'sandbox'bind'unix://tmp/puma.sock'stdout_redirect'log/puma.log','log/puma_error.log',truepidfile'tmp/pids/puma.pid'state_path'tmp/pids/puma.state'daemonizetrueworkers4我通过以下

ruby - 如何测试两个时间范围是否重叠?

我需要实现预订功能并确保预订不会在Rails应用中重叠。cover?和between?方法并不是我所需要的。与同一模型上的其他潜在范围相比,我必须确保时间范围的唯一性,并且要高效地做到这一点。我认为可以使用overlaps?来完成.问题是,对于这样的事情,它会返回TRUE:(1..5).overlaps?(5..9)=>true如果我比较一个预订在另一个预订开始时结束(3:30-4:00与4:00-4:30),它会说他们做重叠,但他们在技术上没有。那会有问题吗?ValidatesOverlap似乎可以解决这个问题,包括边缘重叠。有什么建议吗? 最佳答案

ruby - 即时读取压缩的 csv 文件

我已经写了一些csv文件并压缩它,使用这个代码:arr=(0...2**16).to_aFile.open('file.bz2','wb')do|f|writer=Bzip2::Writer.newfCSV(writer)do|csv|(2**16).times{csv我想阅读这个csvbzip2ed文件(用bzip2压缩的csv文件)。这些未压缩的文件如下所示:1,24,125,28,71,3...所以我尝试了这段代码:Bzip2::Reader.open(filename)do|bzip2|CSV.foreach(bzip2)do|row|putsrow.inspectendend

ruby - 为什么会出现未初始化常量 Stuff::HTTPParty 错误?

我的系统上有HTTPartygem,我可以在Rails中使用它。现在我想单独使用它。我正在尝试:classStuffincludeHTTPartydefself.yHTTParty.get('http://www.google.com')endendStuff.y但是我明白了$rubytest_httparty.rbtest_httparty.rb:2:in`':uninitializedconstantStuff::HTTParty(NameError)fromtest_httparty.rb:1:in`'07:46:52durrantmCastle2012/home/durrant

Ruby 数组 - 如何使值在 nil 值上保持不变

我正在处理一系列midi音高,看起来像这样......pitches=[60,nil,nil,nil,67,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil]在这种情况下,索引1、2和3上的间距仍然是60。索引4之后,音高仍然是67。如何编写一个方法来识别先前的非零值?目前我能想到的唯一方法看起来有点笨拙:defpitch_at_step(pitches,step)ifpitches.any?x=pitches[step]

ruby-on-rails - 查找具有大于某个关联的 x 的所有对象

我有很多农场,每个农场都有很多动物。我需要找到每个拥有5只以上动物的农场。我需要类似这样的东西...:Farm.where(animals.count>5)更新/回答:Farm.joins(:animals).group("farm_id").having("count(farm_id)>5") 最佳答案 尝试:Farm.joins(:animals).group("farm.id").having("count(animals.id)>?",5)引用:https://stackoverflow.com/a/9370734/4297