草庐IT

ruby - Ruby 方法 'to_sym' 有什么作用?

to_sym方法有什么作用?它有什么用? 最佳答案 to_sym将字符串转换为符号。例如,"a".to_sym变为:a。它不是Rails特有的;vanillaRuby也有它。看起来在某些版本的Ruby中,符号也可以与Fixnum相互转换。但是来自ruby​​-lang.org的Ruby1.9.2-p0的irb不允许这样做,除非您将自己的to_sym方法添加到Fixnum。我不确定Rails是否会这样做,但它似乎在任何情况下都不是很有用。 关于ruby-Ruby方法'to_sym'有什么作

ruby-on-rails - 如何将哈希键从 `Symbol` s 更改为 `String` s?

我正在使用RubyonRails3.2.2,我想“轻松”/“快速”将散列键从Symbol更改为String。也就是说,从{:one=>"Value1",:two=>"Value2",...}到{"one"=>"Value1","two"=>"值2",...}.我怎样才能使用尽可能少的代码来做到这一点? 最佳答案 只需调用stringify_keys(或stringify_keys!)http://apidock.com/rails/Hash/stringify_keys 关于ruby-o

ruby - 字符串#count 选项

来自documentationforString#count我理解第一个示例,但我不理解其余示例:a="helloworld"a.count"lo"#=>5a.count"lo","o"#=>2a.count"hello","^l"#=>4a.count"ej-m"#=>4任何解释都会有所帮助。 最佳答案 这是最笨拙的ruby​​方法之一,而且启动文档非常糟糕。把我扔了一个循环。我最终查看了它,因为它看起来应该给我给定字符串的出现次数。没有。远不近。但这是我最终计算字符串出现次数的方式:s="thisisastringwithist

ruby - 你如何在 Ruby 中循环遍历多行字符串?

来自新手Ruby程序员的非常简单的问题。如何在Ruby中循环遍历一段文本?每次遇到换行符,我都想重新启动内循环。defparse(input)...end 最佳答案 String#each_linestr.each_linedo|line|#dosomethingwithlineend 关于ruby-你如何在Ruby中循环遍历多行字符串?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questio

ruby - 使用 Ruby 将大写字符串转换为标题大小写

我正在尝试将Ruby中的全大写字符串转换为小写字符串,但每个单词的第一个字符都是大写。示例:将“我的字符串在这里”转换为“我的字符串在这里”。我知道我可以使用.downcase方法,但这会使所有内容都变成小写(“我的字符串在这里”)。我正在扫描文件中的所有行并进行此更改,那么是否有可以通过ruby​​使用的正则表达式来实现此目的?谢谢! 最佳答案 如果您正在使用Rails(您真正需要的只是ActiveSupport,它是Rails的一部分),您可以使用titleize:"MYSTRINGHERE".titleize#=>"MyStr

ruby - 如何在 ruby​​ 中针对正则表达式测试整个字符串?

如果整个字符串匹配(而不是子字符串),我如何针对正则表达式设置字符串以返回true?例如:test(\ee\,"street")#=>returnsfalsetest(\ee\,"ee")#=>returnstrue!谢谢。 最佳答案 您可以用\A匹配字符串的开头,用\Z匹配结尾。在ruby​​中,^和$也分别匹配行的开头和结尾:>>"a\na"=~/^a$/=>0>>"a\na"=~/\Aa\Z/=>nil>>"a\na"=~/\Aa\na\Z/=>0 关于ruby-如何在ruby​​

ruby - 在 Rails 中,如何向 String 类添加一个新方法?

我想为我的Rails项目中的不同对象构建一个索引,并想添加一个我可以在String对象上调用的“count_occurences”方法。我看到我可以做类似的事情classStringdefself.count_occurencesdo_something_hereendend定义此方法的确切方法是什么,以及将代码放在我的Rails项目中的什么位置?谢谢 最佳答案 您可以在lib/ext/string.rb的应用程序中定义一个新类,并将以下内容放入其中:classStringdefto_magic"magic"endend要加载此类,

Ruby 将 CSV 文件读取为 UTF-8 和/或将 ASCII-8Bit 编码转换为 UTF-8

我正在使用ruby1.9.2我正在尝试解析包含一些法语单词(例如spécifié)的CSV文件,并将内容放入MySQL数据库中。当我从CSV文件中读取行时,file_contents=CSV.read("csvfile.csv",col_sep:"$")返回的元素是ASCII-8BIT编码的字符串(spécifié变为sp\xE9cifi\xE9),然后像“spécifié”这样的字符串没有正确保存到我的MySQL数据库中。YehudaKatz表示ASCII-8BIT实际上是“二进制”数据,这意味着CSV不知道如何读取适当的编码。所以,如果我尝试让CSV强制编码如下:file_cont

ruby - 为什么 Ruby 没有真正的 StringBuffer 或 StringIO?

我最近读了一篇不错的post关于在Ruby中使用StringIO。不过,作者没有提到的是StringIO只是一个“I”。没有“哦”。你不能这样做,例如:s=StringIO.newsshouldbe"foo\nbar"#=>reallyis''`Ruby确实需要一个StringBuffer,就像Java那样。StringBuffers有两个重要的用途。首先,它们让您测试Ruby的StringIO所做的一半输出。其次,它们对于从小部分构建长字符串很有用——Joel一遍又一遍地提醒我们,否则会非常非常慢。有好的替代品吗?的确,Ruby中的字符串是可变的,但这并不意味着我们应该始终依赖该功能

ruby - 用多个定界符拆分字符串

我想使用单个ruby​​命令按空格、、和'拆分字符串。word.split将被空格分割;word.split(",")会被,分割;word.split("\'")将按'拆分。如何同时做这三件事? 最佳答案 word="Nowisthe,timefor'allgoodpeople"word.split(/[\s,']/)=>["Now","is","the","time","for","all","good","people"] 关于ruby-用多个定界符拆分字符串,我们在StackOve