这个问题在这里已经有了答案:Determiningifavariableiswithinrange?(10个答案)关闭7年前。是否有一种简单的方法可以使用(2..100)语法评估整数是否在该范围内。例如,如果我的整数x=100并且我的范围是(0..200),我想评估为真,我只是在看对于这样做的简单、简洁的ruby方式。
我可以生成几行代码来执行此操作,但我想知道是否有一种干净的Rubyesque方法可以执行此操作。如果我不清楚,我正在寻找的是一个数组方法,如果给定(比如)[3,3,3,3,3]或将返回true["rabbits","rabbits","rabbits"]但是[1,2,3,4,5]或["rabbits","将返回false兔子”,“野兔”]。谢谢 最佳答案 您可以使用Enumerable#all?如果给定block对集合中的所有元素都返回true,则返回true。array.all?{|x|x==array[0]}(如果数组为空,则永
我的模型中有一个数组字段,我正在尝试更新它。我的强参数方法如下defpost_paramsparams["post"]["categories"]=params["post"]["categories"].split(",")params.require(:post).permit(:name,:email,:categories)end我在Controller中的Action如下defupdatepost=Post.find(params[:id]ifpostandpost.update_attributes(post_params)redirect_toroot_urlelsere
如果a是数组,我想要a.index(a.max),但更像Ruby。这应该是显而易见的,但我在so和其他地方找不到答案。显然,我是Ruby的新手。 最佳答案 对于Ruby1.8.7或更高版本:a.each_with_index.max[1]它进行一次迭代。不完全是最语义化的东西,但如果你发现自己经常这样做,我会把它包装在index_of_max方法中。 关于ruby-在Ruby中,获取数组中最大值索引的最简洁方法是什么?,我们在StackOverflow上找到一个类似的问题:
我正在使用ruby1.9.2我正在尝试解析包含一些法语单词(例如spécifié)的CSV文件,并将内容放入MySQL数据库中。当我从CSV文件中读取行时,file_contents=CSV.read("csvfile.csv",col_sep:"$")返回的元素是ASCII-8BIT编码的字符串(spécifié变为sp\xE9cifi\xE9),然后像“spécifié”这样的字符串没有正确保存到我的MySQL数据库中。YehudaKatz表示ASCII-8BIT实际上是“二进制”数据,这意味着CSV不知道如何读取适当的编码。所以,如果我尝试让CSV强制编码如下:file_cont
有没有更好的写法:ifmyarray.include?'val1'||myarray.include?'val2'||myarray.include?'val3'||myarray.include?'val4' 最佳答案 使用集合交集(Array#:&):(myarray&["val1","val2","val3","val4"]).present?你也可以循环(any?会在第一次出现时停止):myarray.any?{|x|["val1","val2","val3","val4"].include?(x)}这对于小数组来说没问题,
我有一个数组和一个返回给定值的值的函数。最终我想创建一个hashmap,它将数组的值作为键值,并将f(key_value)的结果作为值。是否有一种干净、简单的方法,类似于数组的每个/映射,使用block来执行此操作?等价于hsh={}[1,2,3,4].eachdo|x|hsh[x]=f(x)end但看起来更像这个,因为它很简单而且只有一行?results=array.map{|x|f(x)} 最佳答案 请注意,从Ruby2.1.0开始,您还可以使用Array#to_h,像这样:[1,2,3,4].map{|x|[x,f(x)]}.
我有以下格式的数据结构:data_hash=[{price:1,count:3},{price:2,count:3},{price:3,count:3}]有没有一种有效的方法来获取:price的值作为[1,2,3]的数组? 最佳答案 首先,如果您使用的是rubyarray=[{:price=>1,:count=>3},{:price=>2,:count=>3},{:price=>3,:count=>3}]然后得到你需要的:array.map{|x|x[:price]} 关于ruby-
是否可以使用Ruby读取文件的修改日期?我已经成功地打开了一个文本文件并捕获了文件的内容File.open("test.txt","r").eachdo|line|"但是读取文件的修改日期会非常有用。 最佳答案 使用mtime:File.mtime("testfile")=>2014-04-1316:00:23-0300 关于ruby-是否可以使用Ruby读取文件的修改日期?,我们在StackOverflow上找到一个类似的问题: https://stacko
有没有一种快速的方法来获取Ruby数组中的所有其他条目?奇数或偶数条目值中包含0。我希望能够像这样使用它:array1+=array2.odd_values或putsarray2.odd_values.join("-")例如更新这正是我所追求的,但我确信还有更短的版本。array1.each_with_indexdo|item,index|if(index%2==0)thenarray2.push(item)endend 最佳答案 a=('a'..'z').to_aa.values_at(*a.each_index.select{|