posts - 13,  comments - 3,  trackbacks - 0

映射类型
    定义:键值对,键不能重复,值可以重复。Python中的映射类型是字典(dict)
    映射的创建
        1. 字面值创建
            eg. d = {'a' : 100, 'b':200 }
        2. 工厂函数dict()创建
            eg1. d = dict([['x', 1], ['y':2]])
            eg2. d = dict(x=1, y=2)
            eg3. d = dict( zip(('x', 'y'), (1,2)) )
        3. 其他函数
            d = dict.fromkeys( (1,2,3), 'value' ) #创建一个dict,键为1,2,3,值为value
    映射的使用
        1. 键值读写
            []操作符:
                可以用来获得值或者设置/新建值
                在读取的时候,如果键不存在,则抛出一个错误
                eg.
                    a = {'x':1, 'y':2}
                    a['z'] = 3         #键不存在,则创建键值对
                    a['x'] = '6'    #键存在,则更新值
                    a['y']            #获得键对应的值
                    #! a['p']        没有对应的键会抛出Error!
            get(key, default=None)
                用来获取值时,如果键不存在也不会抛出错误,会返回default值
            NOTE: 没有set方法
        2. 遍历:
            keys --> 键遍历
            values --> 值遍历
            items --> 键值遍历
            利用sorted(dict) --> 有序的键遍历(对键排序)
            eg. TestTraversal.py
        3. 常用操作
            删除
                del a['x']    #删除键为'x'的条目
                a.clear        #清除字典
                a.pop('x')    #删除键为'x'的条目并返回其值
                a.popitem()    #弹出一个(k,v)对并返回。如果a为空则报错
            判断
                k in/not in dict
        4. 常用函数表
            方法名字                操作
            dict.clear()        删除字典中所有元素
            dict.copy()            返回字典(浅复制)的一个副本
            dict.fromkeysc(seq,
            val=None)            创建并返回一个新字典,以seq 中的元素做该字典的键,val 做该字典
                                中所有键对应的初始值(如果不提供此值,则默认为None)
            dict.get(key,
            default=None)        对字典dict 中的键key,返回它对应的值value,如果字典中不存在此
                                键,则返回default 的值(注意,参数default 的默认值为None)
            dict.has_key(key)    如果键(key)在字典中存在,返回True,否则返回False.
                                在Python2.2版本引入in 和not in 后,此方法几乎已废弃不用了,但
                                仍提供一个可工作的接口。
            dict.items()        返回一个包含字典中(键, 值)对元组的列表
            dict.keys()            返回一个包含字典中键的列表
            dict.iter()            方法iteritems(), iterkeys(), itervalues()与它们对应的非迭代方法
                                一样,不同的是它们返回一个迭代子,而不是一个列表。
            dict.pop(key
            [, default])        和方法get()相似,如果字典中key 键存在,删除并返回dict[key],如果
                                key 键不存在,且没有给出default 的值,引发KeyError 异常。
            dict.setdefault(key,
            default=None)        和方法set()相似,如果字典中不存在key 键,由dict[key]=default为它赋值。
            dict.update(dict2)    将字典dict2 的键-值对添加到字典dict
            dict.values()        返回一个包含字典中所有值的列表
    映射的键
        什么可以做为映射的键? --> 可hash的
        什么可hash?
            1. 不可变对象 (数字,字符串。。。)
            2. 仅包含不可变对象的不可变容器(仅包含不可变对象的元组)
            3. 实现了__hash__()方法的类(可能是可变对象)

集合类型(Set)
    特点:无顺序,不能重复
    分类:可修改的集合和不可修改的集合
    创建:
        >>> s = set('cheeseshop')
        >>> s
        set(['c', 'e', 'h', 'o', 'p', 's'])
        >>> t = frozenset('bookshop')
        >>> t
        frozenset(['b', 'h', 'k', 'o', 'p', 's'])
    使用:
        >>> 'k' in s
        False
        >>> 'k' in t
        True
        >>> 'c' not in t
        True
        >>> for i in s:
        ... print i
    操作
        函数/方法名                    等价运算符                说明
    所有集合类型
        len(s)                                            集合基数: 集合s 中元素的个数
        set([obj])                                         可变集合工厂函数; obj 必须是支持迭代的,由obj 中
                                                        的元素创建集合,否则创建一个空集合
        frozenset([obj])                                不可变集合工厂函数; 执行方式和set()方法相同,但它
                                                        返回的是不可变集合
                                    obj in s             成员测试:obj 是s 中的一个元素吗?
                                    obj not in s         非成员测试:obj 不是s 中的一个元素吗?
                                    s == t                 等价测试: 测试s 和t 是否具有相同的元素?
                                    s != t                 不等价测试: 与==相反
                                    s < t                 (严格意义上)子集测试; s != t 而且s 中 所 有的元素都是t 的成员
        s.issubset(t)                 s <= t                 子集测试(允许不严格意义上的子集): s 中所有的元素    都是t 的成员
                                    s > t                 (严格意义上)超集测试: s != t 而且t 中所有的元素都是s 的成员
        s.issuperset(t)             s >= t                 超集测试(允许不严格意义上的超集): t 中所有的元素    都是s 的成员
        s.union(t)                     s | t                 合并操作:s 或t 中的元素
        s.intersection(t)             s & t                 交集操作:s 和t 中的元素
        s.difference(t)             s - t                 差分操作: s 中的元素,而不是t 中的元素
        s.symmetric_difference(t)    s ^ t                 对称差分操作:s 或t 中的元素,但不是s 和t 共有的元素
        s.copy()                                         复制操作:返回s 的(浅复制)副本
    仅用于可变集合
        s.update(t)                 s |= t (Union)         修改操作: 将t 中的成员添加s
        s.intersection_update(t)     s &= t                 交集修改操作: s 中仅包括s 和t 中共有的成员
        s.difference_update(t)         s -= t                 差修改操作: s 中包括仅属于s 但不属于t 的成员
        s.symmetric_
        difference_
        update(t)                     s ^= t                 对称差分修改操作: s 中包括仅属于s 或仅属于t 的成员
        s.add(obj)                                         加操作: 将obj 添加到s
        s.remove(obj)                                     删除操作: 将obj 从s 中删除;如果s 中不存在obj,将引发KeyError
        s.discard(obj)                                     丢弃操作: remove()的友好版本-如果s中存在obj,从s中删除它
        s.pop()                                         Pop 操作: 移除并返回s 中的任意一个元素
        s.clear()                                         清除操作: 移除s 中的所有元素

note note

posted on 2011-06-10 15:23 Antony Lee 阅读(444) 评论(1)  编辑  收藏 所属分类: Python学习笔记

FeedBack:
# re: Core Python Programming 学习笔记6 - Mapping and Set
2012-03-07 12:56 | 编程笔记
刚好在学python. 谢谢分享!  回复  更多评论
  

只有注册用户登录后才能发表评论。


网站导航:
 

<2011年6月>
2930311234
567891011
12131415161718
19202122232425
262728293012
3456789

常用链接

留言簿(1)

随笔分类

随笔档案

文章分类

搜索

  •  

最新评论

阅读排行榜

评论排行榜