.map在下面做什么:
params = (0...param_count).map
.map在下面做什么:
params = (0...param_count).map
当前回答
0 . .Param_count表示“直到并包括Param_count”。 0…Param_count表示“直到但不包括Param_count”。
Range#map并不返回一个Enumerable,它实际上是将它映射到一个数组。它与Range#to_a相同。
其他回答
它将一个函数“映射”到Enumerable中的每个项——在本例中是一个范围。因此,对于从0到param_count的每一个整数,它都会调用传递一次的块(exclusive -关于点,您是对的),并返回一个包含每个返回值的数组。
下面是Enumerable#map的文档。它还有一个别名collect。
0 . .Param_count表示“直到并包括Param_count”。 0…Param_count表示“直到但不包括Param_count”。
Range#map并不返回一个Enumerable,它实际上是将它映射到一个数组。它与Range#to_a相同。
使用ruby 2.4,你可以使用transform_values完成同样的事情,这个特性是从rails提取到ruby的。
h = {a: 1, b: 2, c: 3}
h.transform_values { |v| v * 10 }
#=> {a: 10, b: 20, c: 30}
#每一个
#each为数组中的每个元素运行一个函数。以下两个代码摘录是等价的:
x = 10
["zero", "one", "two"].each{|element|
x++
puts element
}
x = 10
array = ["zero", "one", "two"]
for i in 0..2
x++
puts array[i]
end
#map
#map对数组的每个元素应用一个函数,返回结果数组。以下是等价的:
array = ["zero", "one", "two"]
newArray = array.map{|element| element.capitalize()}
array = ["zero", "one", "two"]
newArray = []
array.each{|element|
newArray << element.capitalize()
}
#地图!
#地图!类似于#map,但在适当的位置修改数组。以下是等价的:
array = ["zero", "one", "two"]
array.map!{|element| element.capitalize()}
array = ["zero", "one", "two"]
array = array.map{|element| element.capitalize()}
map,以及select和每一个都是Ruby在我的代码中的一个主力。
它允许您在数组的每个对象上运行一个操作,并将它们全部返回到相同的位置。一个例子是将一个数字数组加1:
[1,2,3].map {|x| x + 1 }
#=> [2,3,4]
如果你可以在数组的元素上运行一个方法,你可以用这样的简写方式来做:
要用上面的例子做到这一点,你必须这样做 类数字 def plusone 自我+ 1 结束 结束 (1、2、3). map (&: plusone) # = >(2、3、4) 为了更简单地使用&快捷技巧,让我们使用一个不同的例子: ["vanessa", "david", "thomas"].map(&:upcase) #=> [" vanessa ", " david ", " thomas "]
在Ruby中转换数据通常涉及一系列映射操作。学习map和select,它们是Ruby主库中最有用的方法。它们都一样重要。
(map也是collect的别名。使用最适合你的概念。)
更多有用信息:
如果你运行each或map的Enumerable对象包含一组Enumerable元素(哈希,数组),你可以在你的块管道中声明这些元素,如下所示:
[["audi", "black", 2008], ["bmw", "red", 2014]].each do |make, color, year|
puts "make: #{make}, color: #{color}, year: #{year}"
end
# Output:
# make: audi, color: black, year: 2008
# make: bmw, color: red, year: 2014
对于哈希(也是一个Enumerable对象,哈希只是一个元组数组,为解释器提供特殊的指令)。第一个“管道参数”是键,第二个是值。
{:make => "audi", :color => "black", :year => 2008}.each do |k,v|
puts "#{k} is #{v}"
end
#make is audi
#color is black
#year is 2008
要回答这个实际问题:
假设params是一个散列,这将是通过它进行映射的最佳方法:使用两个块参数而不是一个来捕获散列中每个解释元组的键和值对。
params = {"one" => 1, "two" => 2, "three" => 3}
params.each do |k,v|
puts "#{k}=#{v}"
end
# one=1
# two=2
# three=3