ruby中數組的常用方法----例子


#初始化

a = Array.new
p a                                     #=>[]

a = Array.new(5)
p a                                     #=>[nil, nil, nil, nil, nil]

a = Array.new(5,0)
p a                                     #=>[0, 0, 0, 0, 0]

city = ["北京", "上海", "廣州"]
  
p city                                  #=> ["北京", "上海", "廣州"]

puts city                               #=>北京
                                        #=>上海
                                        #=>廣州

city = Array.new
city[0] = "北京"
city[1] = "上海"
city[2] = "廣州"
p city                                  #=> ["北京", "上海", "廣州"]

city = %w(北京 上海 廣州)
p city                                  #=> ["北京", "上海", "廣州"]

#使用split函數進行分隔

city = '北京,上海,廣州'.split(',')                 

p city                                            #=> ["北京", "上海", "廣州"]

#使用%W{...}將字符串轉換成數組

str = "深圳"
city_1 = %W{北京  上海  廣州 #{str}}               

p city_1                                          #=>["北京", "上海", "廣州", "深圳"]

#使用%w{...}進行轉換

str = "深圳"
city_2 = %w{北京  上海  廣州 #{str}}
              
p city_2                                          #=>["北京", "上海", "廣州", "\#{str}"]

r = 1..5                                          # Range

#使用to_a、entries將范圍類型數據轉換成數組

p r.to_a                                          # Array, to_a等同於entries #=> [1, 2, 3, 4, 5]

p r.entries                                       #=> [1, 2, 3, 4, 5]

r = 'a'..'e'

p r.to_a                                          #=> ["a", "b", "c", "d", "e"]

#基本操作 

#數組的長度會按需要自動增加

city = Array.new

puts "數組的長度為:" + city.size.to_s             #0

city[2] = "香港"
puts "數組的長度為:" + city.size.to_s             #3

p city                                            #=> [nil, nil, "香港"]

city = ["北京", "上海", "廣州", "深圳"]
  
#對一個元素賦值
  
city[4] = "香港"

#得到數組長度

puts "數組的長度為:" + city.size.to_s             #=> 數組的長度為:5

puts "數組的長度為:" + city.length.to_s           #5

puts "數組的長度為:" + city.count.to_s            #5

p city                                            #=> ["北京", "上海", "廣州", "深圳", "香港"]

#獲取某一元素

puts "第二個元素為:" + city[1]                    #上海

puts "倒數第二個元素為:" + city[-2]               #深圳
  
college = ["北京大學", "清華大學"]
  
college.unshift("浙江大學", "復旦大學")        #向數組頭部添加元素列表

college.push("南京大學", "武漢大學")           #向數組尾部添加元素列表 

college << "南開大學"                          #向數組尾部添加一個元素

puts college.size.to_s                        #=> 7

p college                                     #=> ["浙江大學", "復旦大學", "北京大學", "清華大學", "南京大學", "武漢大學", "南開大學"]

#獲取數組第一個元素,first(n),取前n個元素           

p college.first                               #=> "浙江大學"

p college.first(3)                            #=> ["浙江大學", "復旦大學", "北京大學"]

#獲取數組最后一個元素,last(n),取后n個元素

p college.last                                #=> "南開大學"

p college.last(3)                             #=> ["南京大學", "武漢大學", "南開大學"]

puts college.shift                            #刪除並獲取數組第一個元素

puts college.pop                              #刪除並獲取數組最后一個元素,pop和push組合起來可以把一個Array直接當成Stack

puts college.size.to_s                        #=> 5

p college                                     #=> ["復旦大學", "北京大學", "清華大學", "南京大學", "武漢大學"]

p college[2,3]                                #截取從索引2開始,長度為3的元素列表

p college[2..3]                               #截取從索引2開始,到索引3的元素列表

p college[2...3]                              #截取從索引2開始,到索引3(不包括)的元素列表

city_1 = ["北京", "上海", "廣州"]
  
city_2 = ["香港", "澳門"]
  
city_3 = city_1 + city_2

puts city_3.size.to_s                         #=> 5

city_1.concat(city_2)

puts city_1.size.to_s                         #=> 5


#兩數組相連 +/concat

#a.concat(b),連結,得到a中所有數據和b中所有數據組成的數組,並保存在a中,a變b不變

p ["北京", "上海", "廣州"].concat(["廣州", "香港", "澳門"])                    #=> ["北京", "上海", "廣州", "廣州", "香港", "澳門"]
  
#a + b,和集,得到a中所有數據和b中所有數據組成的數組,a、b均不變
  
p ["北京", "上海", "廣州"] + ["廣州", "香港", "澳門"]                          #=> ["北京", "上海", "廣州", "廣州", "香港", "澳門"]
  
#a - b,差集,得到由a中元素去除同時存在於a數組和b數組中的元素后剩余元素組成的數組
  
p ["北京", "上海", "廣州"] - ["北京", "香港", "澳門"]                          #=> ["上海", "廣州"]
  
#p&b,交集,取兩個數組中都存在的元素,等於 a - (a - b)和b - (b - a)
  
p (["北京", "上海", "廣州"] & ["北京", "香港", "澳門"])                        #=> ["北京"]
 
#a|b,並集,合並兩個數組,並保證元素的唯一性,等於(a - b) + (b - a) + a&b
  
p (["北京", "上海", "上海", "廣州"] | ["北京", "香港", "澳門"])                #=> ["北京", "上海", "廣州", "香港", "澳門"]
  
#include?(obj),判斷數組元素中是否包含指定對象
  
citys = ["北京", "上海", "廣州", "香港", "澳門"]
puts citys.include? "上海"                                      #=> true

#delete(X),刪除數組中所有與X相同的元素, 返回X

citys = ["北京", "上海", "廣州", "北京", "香港", "澳門"]
p citys.delete("北京")                                          #=> "北京"

p citys                                                         #=> ["上海", "廣州", "香港", "澳門"]

#delete_at(n),刪除第n個元素,返回被刪除的元素對象

citys = ["北京", "上海", "廣州", "北京", "香港", "澳門"]
p citys.delete_at(3)                                            #=> "北京"

p citys                                                         #=> ["北京", "上海", "廣州", "香港", "澳門"]

#delete_if,刪除滿足條件的元素,返回處理后的原數組

abc = [ "a", "b", "b", "b", "c" ]
p abc.delete_if {|x| x >= "b" }                                 #=> ["a"]


#slice/each_slice/each_cons
  
#slice(m, n)返回原數組中下標為m到下標為n之間的元素組成的數組
#slice!(m, n),同時改變原數組,從原數組中刪除返回的元素
  
citys = ["北京", "上海", "廣州", "香港", "澳門"]
p citys.slice(1, 3)                                             #=> ["上海", "廣州", "香港"]
p citys                                                         #=> ["北京", "上海", "廣州", "香港", "澳門"]
p citys.slice!(1, 3)                                            #=> ["上海", "廣州", "香港"]
p citys                                                         #=> ["北京", "澳門"]

#each_slice,迭代取出間隔分割的數組,返回nil

citys = ["北京", "上海", "廣州", "香港", "澳門"]
citys.each_slice(2){|city|
  p city
}
#=> ["北京", "上海"]
#=> ["廣州", "香港"]
#=> ["澳門"]

#each_cons,迭代取出滑動分組的數組,返回nil

citys = ["北京", "上海", "廣州", "香港", "澳門"]
citys.each_cons(2){|city|
  p city
}
#=> ["北京", "上海"]
#=> ["上海", "廣州"]
#=> ["廣州", "香港"]
#=> ["香港", "澳門"]


#insert(n, obj),在某序列前插入元素對象,改變原數組

citys = ["北京", "上海", "廣州", "香港", "澳門"]
p citys.insert(2, "2")                                          #=> ["北京", "上海", "2", "廣州", "香港", "澳門"]
p citys                                                         #=> ["北京", "上海", "2", "廣州", "香港", "澳門"]

#a[n..m],選擇改變數組

citys = ["北京", "上海", "廣州", "香港", "澳門"]
citys[1..3] = [1, 2, 3]   
p citys                                                         #=> ["北京", 1, 2, 3, "澳門"]


#Array.flatten,將數組中類型為數組的元素中的所有元素取出插入原數組中
#重復這個操作,直到原數組中所有的元素的數據類型均不為數組
#Array.flatten(n),重復n次轉變操作,結束后數組中元素仍可能為數組

nums = [[1, 2], [[2, 3], [3, 4]], 6]
p nums.flatten               #=> [1, 2, 2, 3, 3, 4, 6]

s = [ 1, 2, 3 ]           # [1, 2, 3]
t = [ 4, 5, 6, [7, 8] ]   # [4, 5, 6, [7, 8]]
a = [ s, t, 9, 10 ]       # [[1, 2, 3], [4, 5, 6, [7, 8]], 9, 10]
p a.flatten               #=> [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

a = [ 1, 2, [3, [4, 5] ] ]
p a.flatten(1)              #=> [1, 2, 3, [4, 5]]
p a.flatten                 #=> [1, 2, 3, 4, 5]

#去重

nums = [1, 1, 2, 2, 3, 3]
p a.uniq                      #去除重復的元素,保證元素唯一   #=>[1, 2, 3]

#排序

arr = [9, 8, 7, 1, 2, 5, 3]
p arr.sort                    #=> [1, 2, 3, 5, 7, 8, 9]
p arr                         #=> [9, 8, 7, 1, 2, 5, 3]
p arr.sort!                   #=> [1, 2, 3, 5, 7, 8, 9]
p arr                         #=> [1, 2, 3, 5, 7, 8, 9]
p arr.sort{|a, b| b<=>a}      #=> [9, 8, 7, 5, 3, 2, 1]

  
wuwei = ['酸', '甘', '苦', '辛', '咸']

#min/min_by/max/max_by取最小/大值,均不改變原數組

#minmax/minmax_by,返回最小值、最大值組成的數組,均不改變原數組

puts wuwei.min                       #=> 咸

#取最大值

puts wuwei.max                       #=> 酸

puts wuwei.min_by{|v|                #=> 咸
  v = '0'
}

puts wuwei.max_by{|w|                #=> 酸
  w = '1'
}

p wuwei                              #=> ["酸", "甘", "苦", "辛", "咸"]

p wuwei.minmax                       #=> ["咸", "酸"]

p wuwei.minmax_by{|w|                #=> ["咸", "酸"]
  w
}

#shuffle,打亂元素順序, 隨機變化( 洗牌)
  
nums = [ 1, 2, 3 ]
p nums.shuffle                     #=> [2, 3, 1]
p nums.shuffle                     #=> [3, 2, 1]
p nums.shuffle                     #=> [1, 3, 2]
p nums.shuffle                     #=> [1, 3, 2]
  
#遍歷
  
#each/each_with_index/cycle/cycle(n)

#each/each()依次取出每一個元素,每次取出的一個元素可以被

#跟隨的塊函數接收,返回原數組;each_with_index/each_with_index()得到

#元素的同時還得到當前元素在數組中的序列值,返回原數組

#cycle,除非遇到break、return、exit等語句,否則無限循環數組,返回nil

#cycle(n),除非遇到break、return、exit等語句,否則循環數組n次,返回nil

nums = [1, 2, 3]
b = nums.each{|value| p value}   #=>1
                                 #=>2
                                 #=>3
puts b                           #=> [1, 2, 3]

nums.each_with_index do |value, index|
  puts "#{index}  :  #{value}"
  puts ( value + index ).to_s
end
                               #=>0  :  1
                               #=>1
                               #=>1  :  2
                               #=>3
                               #=>2  :  3
                               #=>5

abc = ('a'..'c').to_a
#abc.cycle {|x| puts x }          # a, b, c, a, b, c,.. forever.

abc.cycle(2) {|x| puts x }       # a, b, c, a, b, c.

#reduce,別名inject,迭代累加/減,不改變原數組

#inject理解的難點在於block中的兩個參數

#sum是上一次block的返回值,默認初始化為0或nil
  
#可以傳入初始值c
  
#value是當前的元素對象
  
arry = (1..3).to_a
n = arry.reduce(:+)
puts n                         #=>6

n = arry.reduce(:-)
puts n                         #=>-4

#帶有初始值的累加
c = 10
n = arry.reduce(c) do |sum, value|
  p sum                             
  sum + value
end
puts n
                                #=>10
                                #=>11
                                #=>13
                                #=>16

puts n = arry.inject(:+)        #=> 6

abc = ('a'..'c').to_a

puts abc.inject(:+)        #=> abc

puts abc.inject('A') {|sum, value| sum + value }      #=> Aabc      
  

#join 返回由數組中各元素連結成的一個字符串,原數組不變
  
abc = ['a', 'b', 'c']
  
p abc.join                     #=> "abc"

p abc.join('-')                #=> "a-b-c"

p abc                          #=> ["a", "b", "c"]

#map, 別名collect,處理數組中的每一個元素並放入新數組中,返回新數組

#map!、collect!將同時改變原數組

arry = %w(a b cD)
p arry                          #=> ["a", "b", "cD"]
s1 = arry.reduce(:+)
s2 = arry.map(&:upcase)
s3 = arry.map do |item|
  item.upcase
end
p arry
p s1
p s2
p s3
                                #=>["a", "b", "cD"]
                                #=>"abcD"
                                #=>["A", "B", "CD"]
                                #=>["A", "B", "CD"]


#find/find_all/select

# find到一個即返回,別名detect

rs = (1..8).to_a.find {|i|
  i % 2 == 0 and i % 4 == 0
}  
p rs                            #=> 4

# find_all找到全部符合條件的對象,別名select

rs = (1..8).to_a.find_all {|i|
  i % 2 == 0 and i % 4 == 0
}  
p rs                            #=> [4, 8]

# select,找到全部符合條件的對象,別名find_all

arry = (1..8).to_a
arrySelect = arry.select { |x| 
  x % 2 == 0 
}
puts arrySelect.to_s            #=> [2, 4, 6, 8]

#take(n)/take_while/drop(n)/drop_while

#取前n個元素/取滿足條件的元素/取除去前n個元素剩余的元素/取除去滿足條件的元素剩余的元素

#返回這些元素組成的數組,不改變原數組

a = ["北京", "上海", "廣州", "香港", "澳門"]
  
p b = a.take(2)                             #=> ["北京", "上海"]

p a                                         #=> ["北京", "上海", "廣州", "香港", "澳門"]

p b = a.drop(2)                             #=> ["廣州", "香港", "澳門"]

b = a.take_while{|value|
  value == '北京'
}

p b                                         #=> ["北京"]

b = a.drop_while{|value|
  value == '北京'
}

p b                                         #=> ["上海", "廣州", "香港", "澳門"]


# reject,迭代數組元素,從原數組中刪除符合條件的元素對象,改變原數組,返回處理后的數組

arry = (1..8).to_a
arryReject = arry.reject { |x| x % 2 == 0 }
puts arryReject.to_s            #=> [1, 3, 5, 7]


#根據條件分組,分組后得到哈希表

arry = (1..8).to_a
arryGroupBy = arry.group_by{ |x| x % 2 == 0 }
puts arryGroupBy                #=> {false=>[1, 3, 5, 7], true=>[2, 4, 6, 8]}

puts arryGroupBy.class          #=> Hash

value = arryGroupBy[false]   
p value                         #=> [1, 3, 5, 7]

puts value.class                #=> Array

arryGroupBy = arry.group_by{ |x| 2 }
puts arryGroupBy                #=> {2=>[1, 2, 3, 4, 5, 6, 7, 8]}

value = arryGroupBy[2]
p value                         #=> [1, 2, 3, 4, 5, 6, 7, 8]

puts value.class                #=>Array

#zip(Array,...),遍歷數組,對每個元素,從各個數組參數中取出與其序列相同的元素,組成新的

#數組作為代碼塊的傳入參數,返回nil

a = [1, 4, 7]
b = [2, 5, 8]
c = [3, 6, 9]
d = a.zip(b, c){|e|
  p e
  e
}
p d
#=> [1, 2, 3]
#=> [4, 5, 6]
#=> [7, 8, 9]
#=> nil


#to_enum,轉變成枚舉類型,這樣可以使用next

#不改變原數組,返回生成的枚舉對象

p f = a.to_enum                             #=> #<Enumerator: [1, 4, 7]:each>

p a                                         #=> [1, 4, 7]

p f.next                                    #=> 1

p f.next                                    #=> 4

#all?/any?/none?/one?
#迭代取出元素並代入代碼塊,代碼塊均返回真?/
#迭代取出元素並代入代碼塊,代碼塊至少有一次返回真?/
#迭代取出元素並代入代碼塊,代碼塊均不返回真?/
#迭代取出元素並代入代碼塊,代碼塊有且僅有一次返回真?
#返回真或假,原數組內容不變

wuxing = ['金', '木', '水', '火', '土']

puts wuxing.all?{|value|                         #=> false
  value == '木'
}

puts wuxing.any?{|value|                         #=> true
  value == '木'
}

puts wuxing.all?{|value|                         #=> true
  value = '木'
}

p wuxing                                         #=> ["金", "木", "水", "火", "土"]

  以上是根據個人的理解總結的一些方法,有理解不到位或錯誤的地方還請大家指正。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM