草庐IT

STRING_OBJECT

全部标签

ruby - Ruby 中用于 "String#include?"的算法

有谁能指出包含的算法是什么?Ruby中的方法?例如"helloworld".include?("hello") 最佳答案 正如emboss在他的回答中所述,String#include调用rb_str_index。此函数依次调用rb_memsearch,它实现了Rabin-Karpstringsearchalgorithm,根据thispost在ruby-forum.com上。 关于ruby-Ruby中用于"String#include?"的算法,我们在StackOverflow上找到一

ruby-on-rails - Ruby/Rails 3.1 : Given a URL string, 删除路径

给定任何有效的HTTP/HTTPS字符串,我想解析/转换它,以便最终结果恰好是字符串的根。因此给出的URL:http://foo.example.com:8080/whatsit/foo.bar?x=yhttps://example.net/我想要结果:http://foo.example.com:8080/https://example.net/我找到了documentation对于URI::Parser不是super平易近人。我最初的天真解决方案是一个简单的正则表达式,例如:/\A(https?:\/\/[^\/]+\/)/(即:匹配协议(protocol)后的第一个斜杠。)欢迎提

ruby - 将 "Growing Object-Oriented Software"技术应用于 Ruby on Rails

我读了GrowingObject-OrientedSoftware,GuidedbyTests史蒂夫·弗里曼和纳特·普赖斯的作品,给人留下了深刻的印象。我想在我使用RSpec的Rails项目中采用本书的思想,尽管它的示例是用Java编写的。本书的一个基本原则是我们应该模拟接口(interface)而不是具体类。他们说我们可以通过提取接口(interface)并命名来改进应用设计。但是,Ruby没有任何语法等同于Java的接口(interface)。我如何将他们的技术用于Rails项目?更新例如,在第126页作者引入了Auction接口(interface)来实现bid方法。首先,他们模

ruby - 是否有与 Rspec 的 “mock().as_null_object” 等效的 Mocha?

是否有与Rspec的“mock().as_null_object”等效的Mocha? 最佳答案 是的。使用“stub_everything()”记录在此处:http://mocha.rubyforge.org/classes/Mocha/API.html#M000004. 关于ruby-是否有与Rspec的“mock().as_null_object”等效的Mocha?,我们在StackOverflow上找到一个类似的问题: https://stackover

ruby - Ruby 的 Object#const_get 是如何工作的?

我最近发现Ruby(2.2.1)有一些“有趣”的行为。moduleFooclassFooendclassBarendendFoo.const_get('Foo')#=>Foo::FooFoo.const_get('Bar')#=>Foo::BarFoo.const_get('Foo::Foo')#=>FooFoo.const_get('Foo::Bar')#=>NameError:uninitializedconstantFoo::Foo::BarFoo.const_get('Foo::Foo::Bar')#=>Foo::BarFoo.const_get('Foo::Foo::Foo:

ruby - 为什么 Ruby String#split 不将连续的尾随定界符视为单独的实体?

我正在读取一个政府文本文件,其中$用作分隔符,但我认为分隔符不重要...所以这是预期的:'a$b$c$d'.split('$')#=>["a","b","c","d"]在我正在处理的数据文件中,列标题行(第一行)被统一填充,即没有空标题,如:'a$b$$d'#or:'a$b$c$'但是,每行可能有连续的尾随分隔符,例如:"w$x$$\r\n"通常,我会阅读每一行并咀嚼。但这会导致String#split将最后两个定界符视为一列:"w$x$$\r\n".chomp.split('$')#=>["w","x"]不做chomp得到我想要的结果,虽然我应该chomp最后一个元素:"w$x$$\

Ruby String#scan 相当于返回 MatchData

正如问题标题中所述,Ruby字符串上是否有等效于String#Scan的方法?但不是只返回每个匹配项的列表,而是返回一个MatchData数组?例如:#Matchesasetofcharactersbetweenunderscorepairs"foo_bar__baz_hashbang".some_method(/_[^_]+_/)#=>[#<MatchData"_bar_"&rt,<MatchData"_baz_"&rt]或者任何我能得到相同或相似结果的方法都是好的。我想这样做是为了找到Ruby字符串中“字符串”的位置和范围,例如"goodbyeand"world"insid

ruby - 无法将 Hash 转换为 String?

我正在尝试解析来自Wordnik的API的JSON响应。这是用Sinatra构建的。我不断收到错误“/word的TypeError”“无法将Hash转换为String”。我是否错误地使用了json解析器?这是我的代码:get'/word'doresp=Wordnik.words.get_random_word(:hasDictionaryDef=>'true',:maxCorpusCount=>20,:minLength=>10)result=JSON.parse(resp)word=result.wordreturnword.to_send 最佳答案

ruby - 在 Ruby 中如何使用 string.tr 将双引号替换为单引号?

如何在Ruby中使用string.tr将双引号替换为单引号? 最佳答案 'abc"def"ghi'.tr('"',"'")#=>abc'def'ghi 关于ruby-在Ruby中如何使用string.tr将双引号替换为单引号?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/3860645/

ruby - String#encode 未修复 "invalid byte sequence in UTF-8"错误

我知道有很多关于此错误的类似问题,而且我已经尝试了很多,但都没有成功。我遇到的问题涉及字节\xA1并且正在抛出ArgumentError:invalidbytesequenceinUTF-8我尝试了以下但没有成功:"\xA1".encode('UTF-8',:undef=>:replace,:invalid=>:replace,:replace=>"").sub('','')"\xA1".encode('UTF-8',:undef=>:replace,:invalid=>:replace,:replace=>"").force_encoding('UTF-8').sub('','')"