草庐IT

Ruby 无法检测字符串中的换行符

我有以下字符串,我想检测那里的换行符。但是Ruby的字符串方法include?检测不到它。我正在运行Ruby1.9.2p290。我哪里出错了?"/'ædres/\nYour".include?('\n')=>false 最佳答案 \n需要在双引号内,否则无法转义。>>"\n".include?'\n'=>false>>"\n".include?"\n"=>true 关于Ruby无法检测字符串中的换行符,我们在StackOverflow上找到一个类似的问题: h

ruby - 评论限制

在ruby​​1.9中,放宽了行结束位置的条件,因此我们现在可以用句号开始一行来显示方法调用。当我们混淆了链式和非链式方法,并希望显示下一个非链式方法的开始位置时,这很方便。如果没有这个新功能,我们能做的最好的可能就是使用缩进:method1(args1).method2(args2).method3(args3)method4(args4).method5(args5).method6(args6)或插入一个空行。但这很不方便,因为我们必须注意缩进,同时,不要忘记在每个方法调用之后加上链中最后一个方法调用之后的句点。正因为如此,我制造了很多错误,要么有一个额外的周期,要么有一个缺失的

ruby - 为什么括号内的换行符会改变算术结果?

为什么下面的表达式会这样解析?括号的优先级应该高于换行符,不是吗?3-(1+1)#=>13-(1+1)#=>2省略加号也会让表达式计算为2:3-(11)#=>2如果我声明为连续的换行符(转义)或将加号移动到第一行,则会实现所需的行为:3-(1\+1)#=>13-(1+1)#=>1 最佳答案 这是因为Ruby将新行识别为表达式的结尾,除非表达式不完整。例如,(1+1)与相同(1;+1)这与+1相同,因为返回了括号内的最后一个表达式。这进一步与1相同。如果行尾有+,则表达式不完整,因此会继续到下一行。这使得:3-(1+1)被解释为3-(

ruby gsub 换行符

我有一个包含换行符的字符串,我想用gsub替换空白。"helloI\r\namatest\r\n\r\nstring".gsub(/[\\r\\n]/,'')类似这样的事情^只有我的正则表达式似乎也在替换'r'和'n'字母。另一个约束是有时模式会重复两次,因此会被一行中的两个空格替换,尽管这不是可取的,但比所有文本都被切开要好。如果有办法只选择换行符。或者,如果在使用正则表达式之外还有更简单的方法来解决这个问题,那就更好了? 最佳答案 如果您有混合的连续换行符并想用单个空格替换,您可以使用以下正则表达式解决方案:s.gsub(/\R

ruby-on-rails - 使用 gsub 将特定字符替换为换行符(Ruby、Rails 控制台)

烦人的问题。我试图用换行符(\n)替换模型描述字段中的所有分号字符。数据库是sqlite。该字段是文本类型。如果我在Rails控制台手动执行此操作(使用\n换行符手动键入单个记录的描述),Rails控制台会自动转义\n,并且描述字段会填充\\n.如果我使用gsub以编程方式执行此操作,我会遇到以下情况:>>s=Sample.find(:first)=>...记录的详细信息...>>s.description.gsub!(/;/,"\n")=>...成功-一切看起来都不错,返回值中的新行由\n...表示>>s.save=>true>>reload!Reloading=>true>>s=S

ruby - Ruby 中的通用换行符支持,包括\r (CR) 行尾

在Rails应用程序中,我正在接受和解析CSV文件,这些文件可能使用以下三种可能的行终止字符中的任何一种进行格式化:\n(LF)、\r\n(CR+LF),或\r(CR)。Ruby的File和CSV库似乎可以很好地处理前两种情况,但最后一种情况(“Macclassic”\r行结尾)不作为换行符处理。能够接受这种格式以及其他格式很重要,因为MicrosoftExcelforMac(在OSX上运行)似乎在导出为“逗号分隔值”时使用它(尽管导出为“Windows逗号分隔”更容易-处理\r\n).Python具有“通用换行支持”,可以毫无问题地处理这三种格式中的任何一种。Ruby中是否有类似的东

ruby-on-rails - WITH A COMMENT 在下一行继续声明

如果我在Ruby中有一个我想在下一行继续的语句,通常我会在该行的末尾添加一个反斜杠,如下所示:printx\+y但是如果我在线上有评论,就不行了:printx#showx+y#showy有解决办法吗?(编辑:Squeegy的解决方案是正确的,实际上,我知道你可以这样做,但我特别想知道是否有办法在与反斜杠相同的行上发表评论)。 最佳答案 您需要在第一行加号。我认为注释不适用于反斜杠puts'abc'+#Startabc'def'#Adddef 关于ruby-on-rails-WITHACO

ruby - 为什么 Ruby 的 'gets' 包含结束换行符?

我从不需要从gets获得的结尾换行符。有一半时间我忘记了chomp它,这是一种痛苦......它为什么在那里? 最佳答案 像puts(听起来很相似)一样,它被设计用来处理行,使用\n字符。gets接受一个可选参数,用于“拆分”输入(或“只读直到它到达”)。它默认为特殊的全局变量$/,默认情况下包含一个\n。gets是一种非常通用的读取流的方法,并包含此分隔符。如果不这样做,部分流内容将会丢失。 关于ruby-为什么Ruby的'gets'包含结束换行符?,我们在StackOverflow上

ruby - 如何使用 Ruby 用一个换行符替换一行中的多个换行符

我有一个用ruby​​编写的脚本。我需要删除任何重复的换行符(例如)\n\n\n到\n我目前的尝试使用成功了(或者更确切地说没有成功)str.gsub!(/\n\n/,"\n")这对我的输出没有任何影响。我做错了什么? 最佳答案 这对我有用:#!/usr/bin/ruby$s="foo\n\n\nbar\nbaz\n\n\nquux";puts$s$s.gsub!(/[\n]+/,"\n");puts$s 关于ruby-如何使用Ruby用一个换行符替换一行中的多个换行符,我们在Stack

ruby - 在 Ruby 中规范化行结尾

我在Ruby中有一个字符串,s(比方说)它可能有任何标准的行结尾(\n,\r\n,\r)。我想将所有这些转换为\n。什么是最好的方法?这似乎是一个非常常见的问题,但没有太多关于它的文档。显然有简单粗暴的解决方案,但是有没有内置的东西来处理这个问题?优雅、惯用的Ruby解决方案是最好的。编辑:意识到^M和\r是一样的。但仍然存在三种情况。(参见wikipedia。) 最佳答案 从ruby​​1.9开始你可以使用String::encode使用universal_newline:true将所有新行放入\n中,同时保持编码不变:s.enc