草庐IT

数字元素

全部标签

arrays - Ruby:删除数组的第一个和最后一个元素 - 为什么解决方案以一种方式而不是另一种方式工作

我想知道为什么第二个解决方案有效,而第一个具有链式方法的解决方案却无效。这个链式方法不起作用:nopers=[5,6,7,8,9]classArraydefine_method(:trimy)doself.shift().pop()endend当我测试nopers.trimy()时,它给出了未定义的错误消息。"method'pop'for1:Fixnum,in'blockin'"并且只执行.pop()方法,删除5。但是,这个版本有效:yuppers=[1,2,3,4,5,6]classArraydefine_method(:trim)doself.shift()self.pop()en

ruby - 如何编写正则表达式以仅查找四位数的数字?

我正在尝试在Ruby中编写一个正则表达式来搜索字符串中只有四位数字的数字。我正在使用/\d{4}/但这是给我四位数或更多位数的数字。例如:“12345-456-6575一些文本9897”在这种情况下,我只需要9897和6575,但我还得到了长度为五个字符的1234。 最佳答案 "12345-456-6575sometext9897".scan(/\b\d{4}\b/)=>["6575","9897"] 关于ruby-如何编写正则表达式以仅查找四位数的数字?,我们在StackOverflo

arrays - 删除存在于另一个数组中的数组元素

有单词表和禁用词表。我想浏览单词列表并编辑所有禁用的单词。这就是我最终所做的(注意catchedbool值):puts"Giveinputtext:"text=gets.chompputs"Giveredactedword:"redacted=gets.chompwords=text.split("")redacted=redacted.split("")catched=falsewords.eachdo|word|redacted.eachdo|redacted_word|ifword==redacted_wordcatched=trueprint"REDACTED"breakend

ruby - 在数字上拆分字符串,保留数字

我有一个字符串,它始终至少是一个数字,但也可以在数字之前和/或之后包含字母:"4""Section2""4Section""Section5Aisle"我需要像这样拆分字符串:"4"becomes"4""Section2"becomes"Section","2""4Aisle"becomes"4","Aisle""Section5Aisle"becomes"Section","5","Aisle"我如何使用Ruby1.9.2做到这一点? 最佳答案 String#split将keepanygroups来自结果数组中的定界符正则表达式。

ruby-on-rails - 如何在 Rails 控制台中将数组的每个元素打印在各自的行中?

当我运行Rails控制台时,如何在单独的行中显示每个项目?而不是>Post.all=>#,#它会显示为>Post.all=>#,#类似于Perl调试器中的x。我试过了Post.all.each{|e|e.inspect+"\n"}但这只会让事情变得更糟,而且不是很方便。我看到了RubyonRails:prettyprintforvariable.hash_set.inspect...isthereawaytoprettyprint.inpsectintheconsole?和https://github.com/michaeldv/awesome_print但这似乎行不通irb(main

ruby - 如何在 Ruby 中将 float 舍入到指定数量的有效数字?

如果有一个等价于R'ssignif的东西就好了Ruby中的函数。例如:>>(11.11).signif(1)10>>(22.22).signif(2)22>>(3.333).signif(2)3.3>>(4.4).signif(3)4.4#It'susually4.40butthat'sOK.Rdoesnotprintthetrailing0's#becauseitreturnsthefloatdatatype.ForRubywewantthesame.>>(5.55).signif(2)5.6 最佳答案 可能有更好的方法,但这似乎

css - Ruby Mechanize 获取具有指定文本的元素

我正在尝试使用mechanize解析网站的内容,但我遇到了困难。我要解析的内容位于li标记内,并且顺序并不总是相同。假设我们有以下情况,其中li标签的顺序并不总是相同,有时甚至根本不存在。title1":herearethedetails"title2":herearethedetails"title3":herearethedetails"title4":herearethedetails"我想要的是仅获取li详细信息,其中span文本例如title3。我所做的是以下内容,它为我提供了第一个li的详细信息:putspage.at('.details').at('span',:text

Ruby 获取二维数组中的对角线元素

我正在尝试使用我的2Druby​​数组解决一些问题,当我进行数组切片时,我的LOC减少了很多。例如,require"test/unit"classLibraryTest我想知道是否有办法得到对角切片?假设我想从[0,0]开始并想要一个3的对角线切片。然后我会从[0,0]、[1,1]、[2,2]获取元素,我会得到一个数组[1,4,7]上面的例子。是否有任何神奇的单行ruby代码可以实现这一目标?3.次做{一些神奇的东西?} 最佳答案 puts(0..2).collect{|i|array[i][i]}

ruby - 在 ruby​​ 中对哈希中的数字求和

我有一个这样的哈希。products={199=>['Shoes',59.99],211=>['Shirts',19.99],245=>['Hats',25.99],689=>['Coats',99.99],712=>['Beanies',6.99]}它有一个商品编号=>[product,price]。我想在不使用inject方法的情况下汇总所有价格。谁能帮帮我? 最佳答案 products.values.map(&:last).reduce(:+)#=>212.95 关于ruby-在r

ruby - 按特定条件删除数组元素

最好的方法是:我有两个数组:a=[['a','one'],['b','two'],['c','three'],['d','four']]和b=['two','three']我想删除a中包含b中的元素的嵌套数组,得到这个:[['a','one']['d','four']谢谢。 最佳答案 a=[['a','one'],['b','two'],['c','three'],['d','four']]b=['two','three']a.delete_if{|x|b.include?(x.last)}pa#=>[["a","one"],["d