草庐IT

date_array

全部标签

arrays - Ruby 中哪个更快, `arr += [x]` 或 `arr << x`

直觉上,后者应该比前者快。然而,当我看到基准测试结果时,我感到非常惊讶:require'benchmark/ips'b=(0..20).to_a;y=21;Benchmark.ipsdo|x|x.report('结果是:Calculating-------------------------------------然而,当我的一位同事独立创建了自己的基准时,结果却恰恰相反:Benchmark.ipsdo|x|x.report('push'){@a=(0..20).to_a;@a.push(21)}x.report('结果:Calculating---------------------

ruby - Date::today 未定义?

为什么只有Date类的某些方法没有显式加载:require'date'线?例如:irb(main):002:0>Date.todayNoMethodError:undefinedmethod`today'forDate:Classfrom(irb):2from/Users/mwlang/.rvm/rubies/ruby-2.0.0-p0/bin/irb:16:in`'然后……irb(main):003:0>require'date'=>true导致...irb(main):004:0>Date.today=>#http://ruby-doc.org/stdlib-2.0/libdoc/

ruby-on-rails - Rails : Date. 今天 - 1.day

使用rails控制台,我只是被这个咬住了:假设今天是12月11日。Date.today-1.day#December10(nospaces)Date.today-1.day#December10(aspaceonbothsidesoftheminussign)Date.today-1.day#December11whaaaat?Date.today-5.days#Stilldecember11!有人能解释一下这是怎么回事吗?我有点担心这在代码中很容易被遗漏。关于如何对此进行编码还有其他建议吗? 最佳答案 您看到的差异是由ruby​​

arrays - Enumerable 的 group_by 是否保留 Enumerable 的顺序?

是否Enumerable#group_by保留每个值内的原始顺序?当我得到这个时:[1,2,3,4,5].group_by{|i|i%2}#=>{1=>[1,3,5],0=>[2,4]}是否保证,例如,数组[1,3,5]包含此顺序的元素,而不是,例如[3,1,5]?有没有关于这一点的说明?我没有提到键1和0之间的顺序。那是一个不同的问题。 最佳答案 是的,Enumerable#group_by保留输入顺序。这是该方法在MRI中的实现,来自https://github.com/ruby/ruby/blob/trunk/enum.c:s

arrays - Ruby - 测试每个数组元素,得到一个结果

我想要一个返回true/false的单行代码,它测试数组中的每个元素是否为整数。因此,如果数组中的任何元素不是Integer,它应该返回false,否则返回true。这是我的尝试:>>([2,1,4].map{|x|(x.is_a?Integer)}).reduce{|x,result|xandresult}=>true>>([2,"a",4].map{|x|(x.is_a?Integer)}).reduce{|x,result|xandresult}=>false还有其他进一步提炼它的想法吗? 最佳答案 array.all?{|x

ruby - 为什么 Array.to_s 返回括号?

对于一个数组,当我输入:putsarray[0]==>text然而当我打字时putsarray[0].to_s==>["text"]为什么是括号和引号?我错过了什么?附录:我的代码如下所示page=open(url){|f|f.read}page_array=page.scan(/regex/)#pullspartialurlsintoanarraypartial_url=page_array[0].to_sfull_url=base_url+partial_url#addseachpartialurltoaconsistentbase_urlputsfull_url我得到的是这样的:

arrays - Ruby 数组上的未定义方法 'to_h'

根据RubyArraydocumentation,有一个方法to_h可以用来将数组转换为散列,只要数组的每个元素都是另一个包含两个元素的数组。来自同一文档的以下示例p[[:foo,:bar],[1,2]].to_h但是,当我运行上面的代码时,出现了这个错误:irb(main):001:0>p[[:foo,:bar],[1,2]].to_hNoMethodError:undefinedmethod`to_h'for[[:foo,:bar],[1,2]]:Arrayfrom(irb):1fromE:/RubyInstall/bin/irb:12:in`'irb(main):002:0>我的

ruby - 导轨 : seeding database data and date formats

我正在尝试使用db/seed.rb文件和rakedb:seed命令将一些数据播种到我正在开发的Rails3应用程序中。我播种的数据涉及一个名为Meeting的数据库表,该表具有三列:字符串标题、日期时间开始日期、日期时间结束日期。我尝试插入的日期时间采用“mm/dd/yyyyhh:mm”格式——例如。“01/02/200313:23”=2003年1月2日下午1:23。但是,DateTime.parse()始终会出现“无效日期”错误——因为它试图以“dd/mm/yyyy”格式解析日期。根据我的谷歌搜索,我被引导相信在解析DateTime对象时,编译器会查看传入的字符串并进行一些仓促的模式

ruby - 为什么 array.min 这么慢?

我注意到array.min看起来很慢,所以我针对我自己的简单实现做了这个测试:require'benchmark'array=(1..100000).to_a.shuffleBenchmark.bmbm(5)do|x|x.report("lib:"){99.times{min=array.min}}x.report("own:"){99.times{min=array[0];array.each{|n|min=nifn结果:Rehearsal-----------------------------------------lib:1.5310000.0000001.531000(1.5

ruby - 'array.each do |block|'在生成的 Haml HTML 中包含语句的结果

我正在生成一封电子邮件,其中包含来自Haml模板的动态内容,该模板解析数组中的信息。基本上,Haml接收一个包含多个哈希值的数组。在代码中,我有一个如下所示的block:%table=arrayname.eachdo|object|%tr%td=object.name%td=object.link每当发送电子邮件时,整个对象arrayname都包含在HTML的底部。这会导致[#,#](当有更多对象时更多#)显示在block的顶部。没有办法用CSS操纵这段文本,否则我会把它隐藏起来。[#,#]该行与在IRB中执行代码时显示的结果相同。谁能告诉我如何防止这种情况发生?