草庐IT

ruby - 如何搜索、递增和替换 Ruby 字符串中的整数子字符串?

我有很多这样的文档:foo_1foo_2foo_3bar_1foo_4...我想通过获取foo_[X]的所有实例并将它们中的每一个替换为foo_[X+1]来转换它们。在这个例子中:foo_2foo_3foo_4bar_1foo_5...我可以用gsub和一个block来做到这一点吗?如果不是,最干净的方法是什么?我真的在寻找一个优雅的解决方案,因为我总是可以暴力破解它,但我觉得有一些正则表达式技巧值得学习。 最佳答案 我(完全)不懂Ruby,但类似这样的东西应该可以工作:"foo_1foo_2".gsub(/(foo_)(\d+)/

ruby 正则表达式 : replace double slashes in URL

除了协议(protocol)定义中的斜杠('http[s]://'、'ftp://'等)之外,我想替换URL中的所有多个斜杠。我该怎么做?此代码无一异常(exception)地替换:url.gsub(/\/\/+/,'/') 最佳答案 您只需排除任何以:开头的匹配项url.gsub(/([^:])\/\//,'\1/') 关于ruby正则表达式:replacedoubleslashesinURL,我们在StackOverflow上找到一个类似的问题: http

Ruby:如何替换文件中的文本?

下面的代码是xml文件中的一行:455360226如何使用ruby​​将2个标签之间的数字替换为另一个数字? 最佳答案 不可能一步修改文件内容(至少我不知道,当文件大小改变时)。您必须读取文件并将修改后的文本存储在另一个文件中。replace="100"infile="xmlfile_in"outfile="xmlfile_out"File.open(outfile,'w')do|out|out\d+/,"#{replace}")end或者您将文件内容读入内存,然后用修改后的内容覆盖文件:replace="100"filename=

ruby-on-rails - rails : replacing try with the Null Object Pattern

在我的大多数应用程序中,我都有一个current_user方法。为了避免像current_user.name这样的情况出现异常,其中current_user是nil,rails提供了try方法。这个问题是我需要记住在current_user可能是nil的地方使用try。我想使用NullObject模式来消除这种额外的开销。classNullUserdefmethod_missing(method_name,*args)nilendenddefcurrent_userreturnNullUser.newunlessUserSession.find@current_user||=UserS

没有正则表达式反向引用的 Ruby 字符串子

我正在尝试用Ruby做一个简单的字符串子。sub()的第二个参数是一长段精简的JavaScript,其中包含正则表达式。此字符串中正则表达式中的反向引用似乎影响了sub的结果,因为被替换的字符串(即第一个参数)出现在输出字符串中。例子:input="stringishere"output=input.sub("","\&")我希望输出为:"string\&ishere"不是:"string&ishere"或者如果转义正则表达式"stringishere"基本上,我想要一些方法来做一个完全没有正则表达式结果的字符串子-只是一个简单的字符串替换。 最佳答案

ruby - 同时替换2个字符串?

如何同时替换2个字符串?例如,假设我有这样的字符串:str1="AAAABBBBCCCCDDDD"我想用“CCCC”替换每个“AAAA”,用“AAAA”替换每个“CCCC”,但如果我这样做了:str1.gsub("AAAA","CCCC")#CCCCBBBBCCCCDDDDstr1.gsub("CCCC","AAAA")#AAAABBBBAAAADDDD我希望str1成为“CCCCBBBBAAAADDDD” 最佳答案 一般答案:使用正则表达式匹配AAAA和CCCC,然后分别用CCCC和AAAA替换每个匹配项。编辑以消除混淆str1.

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('','')"

ruby - ruby 如何完成这项任务(Ruby 中不区分大小写的字符串搜索和替换)?

我在用Ruby替换字符串时遇到一些问题。我的原文:人之所为不如兽之所为。我想替换为:==What==humandoesisnotlike==what==animaldoes.我在使用gsub时遇到区分大小写的问题。(例如,什么,什么)我想保留原始文本。有什么解决办法吗? 最佳答案 如果我理解正确,这就是你想要做的:puts"Whatthehumandoesisnotlikewhatanimaldoes.".gsub(/(what)/i,'==\1==')输出==人类所做的==不同于==动物所做的。

ruby-on-rails - rails 上的 ruby : replace camel case with space

我想将camelCase之类的驼峰式单词转换为CAMELCASE。我尝试了提到的方法here.@q=params[:promo].underscore.humanize.upcase但这给了我CAMELCASE而不是CAMELCASE使用相同的结果:@q=params[:promo].gsub(/[a-zA-Z](?=[A-Z])/,'\0').downcase编辑:url包含/camelCase但在使用params[:promo]时,不保留驼峰式并且@q是camelcase 最佳答案 »'camelCase'.underscore

ruby 正则表达式 : replace non-word chars that are not space chars

如何替换所有也不是空格字符(\s)的非单词字符(\W)?这是所需的功能:"the(quick)!brown\nfox".gsub(regex,"#")=>“#quick##brown\nfox” 最佳答案 "the(quick)!brown\nfox".gsub(/[^\w\s]/,"#")通过使正则表达式替换任何不是单词字符或空格字符的内容。 关于ruby正则表达式:replacenon-wordcharsthatarenotspacechars,我们在StackOverflow上找到