python 之 列表与字典
1.4 列表与字典
列表与字典,这两种类型,都是各种类型的集合,以列表为例,如果列表中包含列表,就形成嵌套。 这两种类型几乎是所有python脚本的主要工作组件 。 这种结构信息是可变的可修改的。不像常量,一旦定义便不能再修改。
- [X]列表 列表有以下几大属性,或者说是特点:- 任意对象的有序集合
- 通过偏移量来读取
- 长度可变,异构及任意嵌套
- 属于可变序列分类 与字符串、常量相比而言,列表是可变的,可以进行修改,增加、合并 ,删除等操作。
- 对象引用数组
- 列表元素以逗号分隔
 - 在标准python解析器中,列表就是C数组,而不是链接结构。 - [X]列表的操作- 关于列表的操作,我们可以通过help(list)或者 dir(list) ,或者用真实的列表替换关键词list 来查看帮助文档。 除此之外,还有一些其他固定的可用操作。 这里先了解一些常用的简单的列表操作方法: - Table 7: 列表操作 - 方法 - 释义 - 示例 - l=[] - 定义列表 - l=['a',2,['b','c,d']] - l=list(…) - 定义列表 - l=[c * 4 for c in 'hal'] - 定义列表 - l.append() - 列表末尾添加新成员,列表、字典作用新成员 - l.append(['a',2,'b'] - l.clear() - 清空列表 - l.clear() - l.copy(value) - 复制列表 - l.copy() - l.count(value) - 统计某个成员在列表中出现的次数 - l.count('b'),l.count(l1, 2) - l.extend(value) - 添加新的内容(如果是列表、字典,则将 - l.extend([3,{4,5}]) - 字典、列表中的成员逐一添加至原列表,其 - 子列表作用一个整体添加)。如果type(value - )=list 则合并,如果type(value)=set,那么 - 字典中的值会反序添加,如果是字符串,则转 - 化为字典进行合并。 - 列表不能添加如l.extend({4,['a']}) - l.index(value,[start,[stop]]) - 返回列表中的值对应的索引序号。在。 - start –> stop之间如果不存在想要查找 - 的值,则报错 - l.index({4,5}) - l.insert(index,object) - 在指定索引位置 前 添加新的列表成员 - l.insert(2,{'a','b'}) - l.pop([index]) - 根据索引位置删除相应内容。 - index的值必须是单个整数,不能以列表、字 - 典等形式传入,也就是只能一次删除一个列表 - 成员。如果指定索引不存在则报错。如果不指 - l.pop(3) - 定索引值,则默认删除最后一个成员。 - l.remove(object) - 从列表中剔除成员。object必须是完整的成员 - l.remove({'a','b'}) - l.reverse() - 将列表成员进行反序排列 - l.reverse() - l.sort(key=None,reverse=False)) - 该方法默认升序排列。当reverse=Ture时,进 - 行反序排列。但是python3.0前后有点区别: - 3.0之前,允许不同元素之间进行排序 。 - 3.0之后,不允许不同类型的列表元素进行排序 - l.sort() - l*2 - 重复列表内容 - list('hal')+list('berd') - 列表合并,实际上是生成了一个新的列表 - l[i:j]=[] - 根据索引替换相应位置的列表元素.从第i个 - 元素开始,包含j个元素。 - len(l) - 返回列表元素的个数 - 3 in l - 判断列表l中是否为有3的元素,注意数据类型 - del l[ [index] ] - 删除列表中的某个元素,或者删除整个列表 - 思考
- 通过使用索引,在列表首尾添加新元素。
答案: l[len[l]:]=[x]; l[:0]=[x] 使用索引进行列表调整,可以实现append,remove,pop,insert等功能. 请注意,添加新元素的数据类型。比如列表与字符串 
 
 
- [X]字典 字典可以说是列表以外最灵活的内置数据结构。 字典有以下属性:- 通过键来存取值而不是通过偏移量,键必须是不可变类型。
- 字典元素为无序集合
- 可变长,异构,任意嵌套
- 属于可变映射类型
- 散列表。通过hash运算进行数据检索。与列表一样存储对象的引用而不是拷贝。
- 字典操作
Table 8: 字典操作 方法 释义 示例 d={} 定义空字典 d={} d={'a':'b','name':'halberd'} 定义字典 d={'name':'halberd'} d=dict(mappint) 定义字典,这种写法比较复杂难懂。由于dict只能接受 d=dict(( ('key1','value1'),('key2','value2'),… )) 一个参数,因此在dict()方法内部必须包含一个代表 整体的符号,可用的为“(),”“[],” 但是"{},"不能用,dict(()) 或者dict([]),在最内部为key/value的值信息,这样 形成三层结构: 第一层为:dict() 第二层为:dict(()) 或者 dict([]) 第三层为:dict((['key1','value1'],('key2','value2'),…)) d=dict(zip(keys,values)) 定义字典。 其中keys,与values 的类型分别可以为字符串, 列表,或者range()等函数返回的一系列值等 d=dict(zip('abcd',range(1,5))) d.clear() 清空字典,不需要传入任何参数。 d.clear() d.copy() 将原字典复制出一个新的字典 e=d.copy() d.fromkeys(iterable,value) 定义一个字典中的keys,并赋予相同的值.value默认为None dict.fromkeys(['a','b'],'123') iterable 可以是列表,也可以是字典。如果是列表,则列表中 dict.fromkeys({'name':'halberd','age':20},100) 每个成员都会转换成key,如果是字典,则将value 赋值给字典 中的key d.get(key[,values]) 取出字典中键对应的值。也可以使用value给予一个新的值。但 对原来的字典无影响。不写value部分的时候取出的是字典中key 对应的值,此时相当于dict[key]。写value里,得到的结果是 d.get('name'[,'guess']) value d.items() 以列表返回可遍历的(键, 值) 元组数组 d.items() d.keys() 以列表返回一个字典所有的键 d.keys() d.values 以列表返回一个字典所有的值 d.values() d.pop(key[,value]) 删除字典中的key及对应的值,同 del d[key] d.pop('name'[,'halberd']) d.popitem() 此方法不需要任何参数,默认删除最后一个key:value. 返回的 d={'name':'halberd','age':2,'gender':'male'} 是被删除的key 及对应的value,以元组形式返回,但是如果是空 d.popitem() 字典,则返回错误信息 d.setdefault(key[,value])) 返回key对应的值,但是如果key在原字典中不存在,则追加 d.setdefault('gender','male') 如果key不存在,并且没有提供对应的value,则默认是'None' d.update() 1. 合并字典。比如dict1与dict2 dict1.update(dict2)会将 d2={'gender':'male'} dict2 的内容合并至dict1,如果dict2包含于dict1,则无变化 d.update(d2) 2. dict1使用update将其他类型的数据,以字典key:value的形 d.update(work='IT-migrant-worker',married='NO') 式合并到dict1中 d.update((['work','IT-migrant-worker'],['married','NO'])) d.update([('work','IT-migrant-worker'),('married','NO')]) d.update(zip(('work','married'),('IT-migrant-worker','NO'))) d.update(zip(['work','married'],['IT-migrant-worker','NO'])) len(dict) 计算字典key=value的个数 len(d) del dict[key] 删除字典中某一个key 及对应值,同dict.pop(key) del d['name'] del dict 删除字典 del d 
 
- 字典操作
 
===================
天行健,君子以自强不息
地势坤,君子以厚德载物
===================

 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号