zoukankan      html  css  js  c++  java
  • ruby正则

    http://simohayha.javaeye.com/blog/147438

    标签:Ruby 语法
    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://blackanger.blog.51cto.com/140924/88709
    一。给Hash添加默认值 :

    h = {1,2,3,4}   #=> {1 => 2, 3 => 4}
    h.default = 7
    h[1]                #=>  2
    h[3]                #=>  4
    h[4]                #=>  7
    h[5]                #=>  7



    二。给Hash添加key-value对:
    h = {}                     #=> {}
    h.store("a",1)         #=> 1
    h["a"]                     #=> 1
    h.fetch("a")            #=> 1
    h["b"] = 2               #=> 2
    h["b"]                     #=> 2
    p  h                        #=> {"a"=>1, "b"=>2}

    store和[]= 方法是别名的关系,  fetch和[]方法是别名的关系。


    三。清除Hash的key-value对:
    h = {:a => 1, :b => 2}

    删除全部的k-v对,有两种方法:
    给hash赋空值
    用clear方法 (这种方法更快一点)

    shift方法随机删除k-v对。
    h = {:a => 1, :b => 2, :c => 3}
    h.shift             #=> [:a, 1]
    h                     #=> {:b=>2, :c=>3}
    a = h.shift       #=> [:c, 3]
    a                     #=> [:c, 3]


    delete, delete_if, reject,reject! 方法删除指定的k-v对:
    h = {:a => 1, :b => 2}
    h.delete(:a)                     #=> 1
    h                                     #=> {:b=>2}
    h = {:a => 1, :b => 2}      #=> {:a=>1, :b=>2}
    h.delete_if {|k,v| v != 3}   #=> {}
    h                                     #=> {}
    h = {:a => 1, :b => 2}      #=> {:a=>1, :b=>2}
    h.delete_if {|k,v| v != 1}   #=> {:a=>1}
    h = {:a => 1, :b => 2}      #=> {:a=>1, :b=>2}
    h.reject {|k,v| v!=2}          #=> {:b=>2}
    h                                     #=> {:a=>1, :b=>2}

    reject方法相当于dup.delete_if{}



    四。颠倒Hash的k-v对。
    h = {:a => 1,:b => 1}        #=> {:a=>1, :b=>1}
    x = h.invert                      #=> {1=>:b}

    invert方法可以颠倒Hash的键-值,可是因为Hash键的唯一性,可能会发生上例那样的数据丢失!

    五。 Hash的迭代:
    有each, each_key, each_value ,each_pair(each方法的别名)
    不举例了。


    六。检测Hash中的key,value:
       检测是否有key:
         has_key?(include? 别名, 只能判断key! ) ,key?, member?
       检测是否有value:
         has_value? value?

    七。将散列转换为数组:
     
    h = {:a => 1, :b => 2}
       h.to_a         #=> [[:a, 1], [:b, 2]]   转换为一个二维数组。
       h.keys         #=> [:a, :b]
       h.values      #=> [1,2]

       下面的方法有用点:
       h = {:a => 1, :b => '2', :c => 5}
       h.values_at(:a,:b)    #=> [1, “2”]    根据指定的key返回对应values的数组


    八。根据条件选择key-value对:
      
    h.detect {|k,v| v == "2"}             #=> [:b, "2"]

       detect和find是别名关系,是Enumerable模块里的方法,Hash类mixin这个模块,所以也可以用。select 方法,别名是find_all,可以返回多个匹配的k-v对:
     
    h.select {|k,v| v.is_a?(Integer)}   #=> [[:a, 1], [:c, 5]]


    九。 Hash的排序:
        可以直接用sort方法,不过会返回一个二维数组。
        值得注意的是,当Hash的key是Symbol类型的时候,sort方法会出错。


    十。 合并两个Hash:
       使用merge方法,( merge!和update是别名关系 (thx Beck) )  。
     
    h1 = {:a => 1, :b => 2}          #=> {:a=>1, :b=>2}
      h2 = {:b => 3, :d => 3}          #=> {:d=>3, :b=>3}
      h1.merge h2                         #=> {:a=>1, :d=>3, :b=>3}
      h2.merge h1                         #=> {:a=>1, :d=>3, :b=>2}

      注意看:b值的变化。
     当然我们可以使用block来改变这一结局:
      h1.merge h2 do |k,old,new|
          old < new ? old : new
      end
    #=> {:a=>1, :d=>3, :b=>2}
    h1.merge h2 do |k,old,new|
        p old
        p new
    end
    #=>2
    #=>3

    (当然我们可以使用rails里active_support实现的revert_merge来实现上述效果)。

    十一。 数组转换为Hash:
      当数组元素为偶数个数的时候:
      
    arr = %w[a b c d]         #=> ["a", "b", "c", "d"]
        h = Hash[*arr]              #=> {"a"=>"b", "c"=>"d"}

       此时数组必须为偶数个元素。


    十二。 当Hash的key是动态变化的时候:

    x = [1,2]                  #=> [1, 2]
    h = {x => 2}            #=> {[1, 2]=>2}
    h[x]                         #=> 2
    x[0] = 5                   #=> 5
    h[x]                         #=> nil
    h.rehash                 #=> {[5, 2]=>2}
    h[x]                         #=> 2

  • 相关阅读:
    菜鸟fork()创建进程新见解
    Linux下select函数的使用
    URAL 1029 Ministry
    URAL 1036 Lucky Tickets
    URAL 1031 Railway Tickets
    URAL 1028 Stars
    URAL 1032 Find a Multiple
    URAL 1037 Memory Management
    URAL 1033 Labyrinth
    URAL 1039 Anniversary Party
  • 原文地址:https://www.cnblogs.com/lexus/p/1940563.html
Copyright © 2011-2022 走看看