jjzjj

ruby - 使用 gsub 时如何限制替换次数?

在Ruby中如何限制String#gsub的替换次数?在PHP中,这可以通过preg_replace轻松完成,它接受一个参数来限制替换,但我不知道如何在Ruby中做到这一点。 最佳答案 您可以在gsub循环中创建一个计数器并递减它。str='aaaaaaaaaa'count=5pstr.gsub(/a/){ifcount.zero?then$&elsecount-=1;'x'end}#=>"xxxxxaaaaa" 关于ruby-使用gsub时如何限制替换次数?,我们在StackOverf

ruby (在 Rails 上)正则表达式 : removing thousands comma from numbers

这看起来很简单,但我遗漏了一些东西。我有大量来自各种来源和不同格式的输入。数字输入123123.45123,45(notethecommausedheretodenotedecimals)1,2341,234.5612,345.6712,345,67(notethecommausedheretodenotedecimals)关于输入的附加信息数字永远小于100万编辑:这些是价格,因此要么是整数,要么是百分之一我正在尝试编写一个正则表达式并使用gsub去除千位逗号。我该怎么做?我写了一个正则表达式:myregex=/\d+(,)\d{3}/当我在Rubular中测试它时,它表明它只在我想

ruby gsub 换行符

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

ruby-on-rails - 如何为 UTF-8 字符串编写带有大引号的 gsub?

我正在为String类编写一个扩展方法来清理非ASCII字符。我正在清理的字符串是UTF-8。当在文件中使用非ASCII字符时,控制台不会启动,因为它将弯引号解释为常规引号。如何转义gsub中的大引号?如何编写将unicode用于大引号(例如U+201C)的gsub。使用Rails3.07和Ruby1.9.2。 最佳答案 您可以在正则表达式中使用与在双引号字符串中使用的相同的\u转义符:s.gsub(/[\u201c\u201d]/,'"')例如:>>s="\u201Cpancakes\u201d"=>"“pancakes”">>p

Ruby 未定义的方法小写

我在以下代码段中遇到异常。谁能告诉我我做错了什么,我该如何预防?defself.find_by_data(data={})where(name_canonical:data['name'].downcase.gsub(/\s+/,''),fuel:data['fuel'],trim_canonical:data['trim'].downcase.gsub(/\s+/,''),year:data['year']).firstend异常(exception):/Users/charlie/Documents/WIP/projectx/ar_models.rb:35:in`find_by_d

Ruby RegEx 问题 text.gsub[^\W-], '' ) 失败

我正在尝试根据我在“RailsWay”中阅读的内容学习Ruby中的RegEx。但是,即使是这个简单的例子也让我感到难过。不知道是不是打错了:text.gsub(/\s/,"-").gsub([^\W-],'').downcase在我看来,这会将所有空格替换为-,然后将字符串以非字母或数字开头且后跟破折号的任何地方替换为“”。但是,使用irb,它首先在^上失败:syntaxerror,unexpected'^',expecting']'如果我取出^,它会在W上再次失败。 最佳答案 >>text="Ilovespaces"=>"Ilov

ruby - 为 6 :Fixnum (Rails) in a view with jQuery + ERB? 获取未定义的方法 `gsub'

我正在尝试向特定View添加一些jQuery+ERB:views/posts/show.html.erb(文件顶部):$(".post-h3").prepend('');postsshow(etc...)">votestrue%>views/layouts/application.html.erb(文件底部):(etc...)但我收到以下错误:undefinedmethod`gsub'for6:FixnumExtractedsource(aroundline#3):1:2:3:$("post-").html('');4:5:有什么解决这个问题的建议吗? 最佳

ruby - 在 Ruby 中使用多个 'gsub' 实例

我正在用Ruby(1.9.3)制作一个基本的翻译器。我从本地测试文件('a.txt')中提取并使用gsub替换某些匹配项以模仿从当代英语到中/早期现代英语的翻译。我遇到了可读性问题:如何使大量的gsub用法更易于阅读?我尝试使用以开头的多行deftranslate@text.gsub(/my/,'mine')@text.gsub(/\sis\s/,'be')end但这只会打印最终的gsub。我只能假设第二个请求会覆盖第一个。我想避免创建大量的gsub请求,但我似乎找不到合适的答案。这是我当前程序的示例:lines=File.readlines('a.txt')@text=lines.j

ruby - 如果需要,如何使用 gsub 添加尾部斜线

如果需要,我正在尝试添加尾部斜线:a='/var/www'a.gsub...我不知道怎么做。 最佳答案 a=File.join(a,"")快捷、简单,并具有保证a以路径分隔符结尾的效果;也就是说,无论a是"/var/www"还是"/var/www/",它都会给出相同的结果。这与上面JoeWhite的评论相同;我不知道他为什么不提交它作为答案,因为它应该是一个。奇怪的是,Pathname库没有提供一种方便的方法来做同样的事情。 关于ruby-如果需要,如何使用gsub添加尾部斜线,我们在S

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