草庐IT

数据增强方法

全部标签

ruby - 如何使用 Ruby 从本地 heroku 生产数据库中将表导出到控制台中的 excel?

我知道如何将Rails中的表格导出到格式化的Excel文件:http://railscasts.com/episodes/362-exporting-csv-and-excel但是如何从控制台执行此操作。 最佳答案 使用连接到您的Heroku数据库herokupg:psql然后运行​​sql命令来获取csv文件,例如\copy(SELECT*FROMusers)TOdump.csvCSVDELIMITER','使用\q退出。执行命令后dump.csv将在您的本地环境中创建 关于ruby-

ruby - 如何使用 Ruby 的文件方法将一个文件的内容复制到另一个文件?

我想使用Ruby的文件方法将一个文件的内容复制到另一个文件。我如何使用一个简单的Ruby程序使用文件方法来做到这一点? 最佳答案 有一个非常方便的方法-IO#copy_stream方法-查看ricopy_stream的输出示例用法:File.open('src.txt')do|f|f.puts'Sometext'endIO.copy_stream('src.txt','dest.txt') 关于ruby-如何使用Ruby的文件方法将一个文件的内容复制到另一个文件?,我们在StackOve

ruby - 在采用多个可选参数的方法中,除了第一个参数之外,如何指定?

我有这样的方法:deffoo(fruit='apple',cut="sliced",topping="icecream")#somelogichereend我怎样才能调用它,我只覆盖顶部参数但对其他参数使用默认值,就像这样foo('','','hotfudge')当然这不会按预期工作,但我只想为第三个可选参数提供一个值,并让前两个保持默认值。我知道如何使用散列来做到这一点,但他们是使用上述语法的快捷方式吗? 最佳答案 从Ruby2.0开始,您可以使用关键字参数:deffoo(fruit:'apple',cut:"sliced",to

ruby-on-rails - Rails 查询执行导致数据库峰值

我的Rails应用程序出现问题,一些随机查询需要大约5秒或更长时间才能完成。大多数时候,查询非常简单(select*fromxwhereid=?),而且字段甚至也被编入索引。这里有一些关于设置的更多信息:反向nginx代理背后的Puma3.5.04个worker,每个worker最少4个,最多8个线程。Rubyv2.2.3,Railsv4.2.4PostgreSQL9.4数据库线程池设置为最多60个连接监控应用8GBRAM、4个CPU、SSD。我在查看Appsignal中的查询性能时发现了这一点。我注意到大多数查询在几毫秒内完成,然后时不时地,仍然在同一个请求中,有多个查询需要5秒以上

ruby-on-rails - Ruby 内置的#permutation 和#repeated_permutation 方法的时间复杂度是多少?

我一直想知道一些Ruby内置方法的时间复杂度,尤其是这两个。我认为我自己能想到的最好的排列方法是Θ(n·n!),Ruby的内置性能更好吗?如果是这样,请帮助我了解他们的算法。 最佳答案 排列Array#permutation返回一个带有n!数组的枚举器,因此时间复杂度至少为O(n!)。我写了这个方法:defslow_method(n)(1..n).to_a.permutation.eachdo|p|pendend它不对p做任何事情,期望强制生成所有排列。构建所有排列的数组会占用太多内存。此方法在n为10到13时被调用了10次,平均秒

ruby - 使用 bundler ,判断 gem 是否为 "requirable"的最佳方法是什么?

在我的Gemfile中说我有group:testdogem'rspec-core',require:falseend有没有一种简单的方法可以查看test组是否已被bundle?(比如,在这种情况下,bundle可能在有或没有--withouttest的情况下被调用)。我找不到,因此我开始寻找是否需要rspec-core,并找到了一些明显的解决方案:Bundler.definition.index.search("rspec-core")#orGem.loaded_specs["rspec-core"]确定是否需要gem的最稳定的API是什么?(不尝试要求它并挽救LoadError)

ruby - 在 Ruby 中使用 Unix 进程控制方法

RyanTomayko用thispost引发了一场激烈的Storm关于使用Unix进程控制命令。Weshouldbedoingmoreofthis.Alotmoreofthis.I'mtalkingaboutfork(2),execve(2),pipe(2),socketpair(2),select(2),kill(2),sigaction(2),andsoonandsoforth.Theseareourfriends.Theywantsobadlyjusttohelpus.我有一些代码(DataMapper的delayed_job克隆,我认为它适合这个,但我不清楚如何利用列出的命令。

Ruby:使用 self 关键字从内部调用私有(private)方法

classMyClassdeftestputsmy_idputsself.my_idendprivatedefmy_id115endendm=MyClass.newm.test此脚本产生输出:115priv.rb:4:in`test':privatemethod`my_id'calledfor#(NoMethodError)frompriv.rb:15:in`'使用self关键字和不使用关键字从内部调用方法有什么区别?根据我的Delphi和C#经验:没有区别,self可以用来避免与局部变量的名称冲突,表示我想调用实例函数或引用实例变量. 最佳答案

ruby-on-rails - 如何在 Rails Controller 中调用 channel 方法?

我有一个订阅用户的ActionCable方法。如果开始新的session,我也想为用户订阅新channel。我想不出在Controller中调用channel方法的正确语法。更新:问题是消息在发送时附加到聊天框,但是当发送第一条消息时,websocket连接尚未建立,因此在用户看来好像消息没有发送(因为它没有被附加)。channel/msgs_channel.rbclassMsgsChannel在我的convosController中,create方法,我尝试了几种方法:convos_controller.rbdefcreate@convo=Convo.create!({sender_

ruby-on-rails - 有没有办法检查 Ruby 变量是否包含二进制数据?

我正在使用Ruby2.4和Rails5。我在名为“content”的变量中有文件内容。内容可能包含来自PDF文件、Word文件或HTML文件之类的数据。有什么办法可以判断变量是否包含二进制数据?最后,我想知道这是PDF、MicrosoftOffice还是其他类型的OpenOffice文件。这个答案——Rails:possibletocheckifastringisbinary?--建议我可以检查变量的编码content.encoding它会产生ASCII-8BIT然而,在二进制数据的情况下,我注意到有些情况下存储在变量中的HTML内容也可能返回“ASCII-8BIT”作为content