草庐IT

each_char

全部标签

ruby-on-rails - rails : switch connection on each request but keep a connection pool

在我们的Rails应用程序中,我们需要根据请求的子域使用不同的数据库(每个国家/地区使用不同的数据库)。现在我们正在做类似于thisquestion中推荐的事情.也就是说,在每个请求上调用ActiveRecord::Base.establish_connection。但是itseemsActiveRecord::Base.establish_connection删除当前连接池并在每次调用时建立一个新连接。我做了这个快速基准测试,看看每次调用establish_connection和已经建立连接之间是否有任何显着差异:require'benchmark/ips'$config=Rails

ruby - 为什么 Array.reverse_each 比 Array.reverse.each 快

我几乎不使用reverse_each方法,而是在需要向后遍历数组时调用reverse.each。所以我只是做了一些基准测试,显然reverse_each比reverse.each快得多。这是因为在使用reverse.each时,在遍历反向数组之前创建反向数组有时间因素吗?然而,在我的示例(下面)中,对于大小为4的数组,TIME(reverse)+TIME(each)-TIME(reverse.each)~1.2秒。这一次无论数组的大小如何,差异或多或少都保持稳定。我已经测试了多达100个元素。是什么导致了这一秒的差异?require'benchmark'number=10000000a

ruby - 如何在 ruby​​ 中读取没有 quote_char 的 CSV?

我有一个没有引号字符的TSV文件。每当数据中出现\t时,它总是分隔列,而不是列值的一部分。每当"出现时,它始终是列值的一部分,并且永远不会包含列值。我想用Ruby阅读这个CSV,但它给了我/Users/.rvm/rubies/ruby-1.9.3-p545/lib/ruby/1.9.1/csv.rb:1925:in`block(2levels)inshift':Illegalquotinginline9506.(CSV::MalformedCSVError)我的代码是:CSV.foreach(input_file,{:col_sep=>"\t",:headers=>true})do|r

ruby - 为什么在 `.each` 之后调用惰性枚举时 `.select` 返回 nil?

我有一段代码是这样的:sent_messages=messages.lazy.reject{|m|message_is_spam?(m)}.each{|m|send_message(m)}#Dosomethingwithsent_messages...某些上下文:如果消息的收件人在过去5分钟内收到消息,则message_is_spam?方法返回true。当messages包含发给同一收件人的多封邮件时,只有在发送第一封邮件后,后一封邮件才会被视为垃圾邮件。为了确保后一条消息被视为垃圾邮件,我懒惰地拒绝垃圾邮件并发送它们。我希望.each返回一个包含所有项目的数组,但我得到的却是nil。

Ruby 最佳实践 : if not empty each do else in one operator

1.我找不到一种优雅的方式来编写这段代码:ifarray.empty?#processemptyarrayelsearray.eachdo|el|#processelendend我想要一个循环,而不用写两次array。我读了this,但没有足够好的解决方案。2。我实际上在HAML模板中。同样的问题。-ifarray.empty?%pNoresult-else%ul-array.eachdo|el|%liel 最佳答案 怎么样?array.eachdo|x|#...puts"x",xend.empty?andbeginputs"emp

Ruby 数组 reverse_each_with_index

我想在数组上使用类似reverse_each_with_index的东西。例子:array.reverse_each_with_indexdo|node,index|putsnodeputsindexend我看到Ruby有each_with_index但它似乎没有相反的。还有其他方法吗? 最佳答案 如果你想要数组中元素的真实索引,你可以这样做['Seriously','Chunky','Bacon'].to_enum.with_index.reverse_eachdo|word,index|puts"index#{index}:#{

ruby-on-rails - 如何在 Openstruct 对象上使用 "each"?

我有一个像这样的OpenStruct散列:#"2","param2"=>"1"},object2={"param1"=>"2","param2"=>"1"},object3={"param1"=>"2","param2"=>"1"}...如何在上面使用each? 最佳答案 OpenStruct有一个名为marshal_dump的方法返回底层哈希结构:your_open_struct.marshal_dump.each{|k,v|puts"#{k}=>#{v}"}如果您使用的是Ruby2.0,您还可以使用to_h像这样:your_op

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上找到

ruby - array.each 和 array.map 有何不同?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:Array#eachvs.Array#mapruby-1.9.2-p180:006>ary=["a","b"]=>["a","b"]ruby-1.9.2-p180:007>ary.map{|val|pval}"a""b"=>["a","b"]ruby-1.9.2-p180:008>ary.each{|val|pval}"a""b"=>["a","b"]ruby-1.9.2-p180:009>ary.map{|val|val["a2","b2"]ruby-1.9.2-p180:010>ary.each{|val

ruby - 为什么 Array#each 返回具有相同元素的数组?

我正在学习each如何在ruby​​中工作的细节,我尝试了以下代码行:p[1,2,3,4,5].each{|element|el}结果是一个数组[1,2,3,4,5]但我不认为我完全理解为什么。为什么each的返回值是同一个数组?每个人不只是提供一种迭代方法吗?或者只是each方法返回原始值的常见做法? 最佳答案 Array#each返回调用它的[array]对象:block的结果是discarded。因此,如果原始数组没有icky副作用,那么什么都不会改变。也许你的意思是使用map?p[1,2,3,4,5].map{|i|i*i}