草庐IT

Linux——vim的使用

全部标签

ruby-on-rails - 如何使用 Ruby 删除文本文件中间的数据行

我知道如何写入文件和从文件读取,但除了将整个文件读入内存、操作它和重写整个文件之外,我不知道如何修改文件。对于大文件,这不是很有效率。我真的不知道附加和写入之间的区别。例如如果我有一个文件包含:Person1,will,23Person2,Richard,32Person3,Mike,44我怎样才能删除包含Person2的行? 最佳答案 您可以通过多种方式删除一行:模拟删除。也就是说,只需用空格覆盖行的内容。稍后,当您读取和处理该文件时,忽略这些空行即可。优点:这既简单又快速。缺点:它不是真正的数据删除(文件不会缩小),您需要在读取

ruby - Vim 和 Ruby - 匹配 "do"s 和 "end"s?

我相信我们都熟悉“意外的kEnd”问题。它们总是(对我来说)很难找到,因为Vim不匹配“do”和“end”。(显然,还有其他以“end”结尾的元素,例如“if”)有没有办法配置Vim来显示这些匹配项以帮助简化调试? 最佳答案 如果您使用的是最新的vim(我使用的是7.4),内置的matchit宏可以很好地处理ruby​​代码。只需将以下内容添加到您的.vimrc中即可启用它runtimemacros/matchit.vim点击%以匹配ruby​​文件中的do/end组合和许多其他组合。

ruby - 如何使用 NGINX 部署 Ruby Rack 应用程序

我想用NGINX部署一个简单的RubyRack服务。我在Internet上阅读了各种内容,但都没有足够的帮助。假设我有这个(实际上它有点复杂,但仍然require'rack'classHelloWorlddefcall(env)[200,{"Content-Type"=>"text/plain"},["Helloworld!"]]endendRack::Handler::Mongrel.runHelloWorld,Port:9292我想知道用NGINX部署它的最佳方式是什么。也许是FCGI或其他东西? 最佳答案 这是您使用unico

ruby - ruby 对象模型的良好解释——主要是 'classes are objects'?

正在研究ruby对象模型,有一些疑问。我理解对象只存储实例变量,方法存储在对象引用的类中的想法。我也理解“self”的概念——它是什么,它如何变化等等。但是,我不明白“类是对象”这一概念。哪里有好的、直观的解释吗?(顺便说一句:我正在使用RubyObjectModelandMetaprogramming和MetaprogrammingRuby作为我的两个资源。如果有人可以提出其他建议,那将会很有帮助。)谢谢。 最佳答案 顾名思义,类就是对象。具体来说,它们是Class类的实例,它本身是Module类的子类,而后者又是Object的子

ruby - Rails 3 - 测试 Controller 的 GET 方法 - 尝试使用 JSON 并出现 406 错误

我有一个简单的Controller,它指定:respond_to:json当我尝试构建这样调用它的功能测试时:test"GET"doget'index',:format=>:jsonend一切正常。但是,如果我尝试像这样传递查询参数:test"GET"doget'index',{:my_param='1234'},:format=>:jsonend我收到Controller返回的406错误。如果我通过response.inspect转储响应,我可以看到@status=406和@header的内容类型为文本/html。如果我通过response.inspect为不传递查询参数的简单情况转

ruby-on-rails - 将 form_for 标签与 get 方法一起使用

我正在尝试使用get方法提交表单。早些时候我尝试用form_tag做类似的事情并且它工作正常但现在当我更改为form_for标签时,这似乎不起作用。filter_path,:method=>:get)do|f|%>我收到一个无路由错误。 最佳答案 如果需要,您可以使用:html传递原始HTML属性。对于Rails3:filter_path,:html=>{:method=>'GET'})do|f|%>更新并且在Rails4中,根据下面@andre.orvalho的建议,可以直接提供method参数:

ruby - 如何在 Heroku 上使用 Ruby Rack 为静态站点设置 URL

我的网站是here.它曾经是一个Django驱动的博客。但是我不再更新它所以我只是想把它变成一个静态的HTML站点。我得到了它并使用RubyRack将它移到了Heroku。但是每个URL都解析为主页。这是因为我的config.ru文件:useRack::Static,:urls=>["/media/images","/media/js","/media/css"],:root=>"public"runlambda{|env|[200,{'Content-Type'=>'text/html','Cache-Control'=>'public,max-age=86400'},File.op

ruby - Rspec——需要 stub File.open 在另一个文件中被调用

在我的测试中,我使用一些参数初始化了一个名为Package的新类。在这个类的初始化中,我打开了一个文件,该文件在我的远程机器上可用,但在本地通常不存在。我想知道如何在我的测试中stub该方法。我正在使用rspec和mocha。我试过类似的东西:File.stubs(:open).with(:file).returns(File.open("#{package_root}/test_files/test.yml"))在我的测试中初始化Package之前,我有这一行。我遇到了这个错误:unexpectedinvocation:File.open('package/test_files/te

ruby - 使用 rspec 测试 Ruby 模块

我很难在SO/Google上找到这个特殊案例。我有一个带有函数的模块,为了使用它们,您必须创建一个包含/扩展模块的类,具体取决于您需要实例方法还是类方法。moduleAdefsay_helloname"hello#{name}"enddefsay_bye"bye"endend如何使用rspec测试此模块?我有这样的事情,我不确定我应该在哪里创建类和扩展模块。describeAdoclassMyClassextendAendbefore(:each){@name="Radu"}describe"#say_hello"doit"shouldgreetaname"doexpect(Mycla

ruby-on-rails - 使用 Ruby/Rails 进行 base 64 URL 解码?

我正在使用FacebookAPI和RubyonRails,我正在尝试解析返回的JSON。我遇到的问题是Facebookbase64URL对其数据进行编码。Ruby没有内置的base64URL解码。关于base64编码和base64URL编码的区别,seewikipedia.我如何使用Ruby/Rails对此进行解码?编辑:因为有些人阅读有困难——base64URL与base64不同 最佳答案 Dmitry的回答是正确的。它说明了在字符串解码之前必须出现的“=”符号填充。我一直收到格式错误的JSON,最后发现这是由于填充造成的。Rea