一、概述:
Python中两种基本的数据结构是序列和映射,序列包含:可变的列表和不可变的元组;而当序列不够用时就出现了映射:字典。列表中的元素是可以变化的,元组里面的元素一旦初始化后就不可更改。列表和元组只是一类元数据的集合体,还不能满足通过名字引用值的数据,故字典就充当了这个功能角色。

二、列表(list):
1.写法示例:x=[1,2,3,4,5] y=['1','2','3','4','5']

2.索引:
x[0]
=>1
y[0]
=>'1'

3.分片:x[:]
=>[1,2,3,4,5]
x[0:3]
=>[1,2,3]
x[0:4:2]
=>[1,3]
可以看出,第一个数字表示起始元素的索引值,第二个数字表示结束元素的值,但不包含它,第三个是步长。注意:这三个数字都可以是负值。

4.序列相加:x+y
=>[1, 2, 3, 4, 5, '1', '2', '3', '4', '5']

5.乘法:x*5
=>[1, 2, 3, 4, 5, 1, 2, 3, 4, 5, 1, 2, 3, 4, 5, 1, 2, 3, 4, 5, 1, 2, 3, 4, 5]

6.成员资格:
1 in x
=> True
6 in x
=> False

7.min,max,len:
min(x)
=>1
max(x)
=>5
len(x)
=>5

8.list函数:list('Hello')
=>['H','e','l','l','o']

9.元素赋值:x[0]=11
=> x=[11,2,3,4,5]

10.删除元素:del x[0]
=> x=[2,3,4,5]

11.分片赋值:x[0:3]=[11,22,33]
=> x=[11,22,33,4,5]

12.append: x.append(6)
=> x=[1,2,3,4,5,6]

13.count: 查找x中元素1出现的次数: x.count(1)
=> 1

14.extend:将一个列表追加到列表末尾: x.extend([6,7,8])
=> x=[1,2,3,4,5,6,7,8]

15.index:找出某个元素的索引位置:x.index(2)=1

16.insert:将元素插入到指定索引前:x.insert(2,10)
=> x=[1,2,10,3,4,5]

17.pop:移除列表中的一个元素,并返回这个元素: x.pop()
=>5
x.pop(0)
=>1

18.remove:移除列表中某个值的第一个匹配项:x.remove(1)
=>x=[2,3,4,5]

19.reverse:反向存放:x.reverse() => x=[5,4,3,2,1]

20.sort,sorted:将列表排序:x.reverse()
=> x=[5,4,3,2,1]
=> x.sort()
=> x=[1,2,3,4,5]
注意:sort并不返回任何值,即:
z=x.sort()
=>z = None.
如果你想对x排序,并且要保留x,有两种方法共选择:
(1)z=x[:]
z.sort()
=> z=[5,4,3,2,1]
(2)z=sorted(x)

21.高级排序:如果你希望按照某种特定的方式排序,可以将函数、方法名作为参数传递给sort.
x.sort(key=cmp,reverse=True) ,其中key和reverse叫做关键字参数,所以您也可以这样写:x.sort(reverse=True,key=cmp),也就是关键字参数可以任意调整参数顺序。
说明:函数cmp(a,b),a>b =>1 , a<b =>-1, a=b =>0
任何适用于列表内元素的函数都可以作为key值传递进去,当然你也可以传递自定义的函数,个人感觉很像.net里面的委托。

三、元组
元组不可修改,字符串也是不可修改的,这个.net中的字符串是一个意思,每次对字符使用+时,都是重新申请了一段新的地址空间,所以我们在处理字符串频繁修改型程序时一般都用StringBuilder.
由于元组和列表最大的不同就是不可修改,所以列表中的 9.元素赋值,10.删除元素,11.分片赋值,12.append,14.extend,16.insert,17.pop,18.remove,19.reverse,20.sort,21.高级排序任何妄图修改元组的函数都不支持。

1.写法:x=1,2,3,4,5 或者 x=(1,2,3,4,5) 或者
x=1, =>x =(1)

2.乘法:
x=(1,2,3,4,5)
x*3
=>(1,2,3,4,5,1,2,3,4,5,1,2,3,4,5)

3.tuple:tuple函数和list函数基本一致:tuple('Hello')
=>('H','e','l','l','o')

4.索引:元组也是序列的一种,所以他也可以用索引来访问元素:
x[0]
=> 1

5.分片:元组也是序列的一种,所以他也可以用索引来分片:
x[0:2]
=>(1,2)

6.成员资格: 1 in x
=> True
6 in x
=> False

7.min,max,len: min(x)
=>1
max(x)
=>5
len(x)
=>5

8.count: 查找x中元素1出现的次数: x.count(1)
=> 1

9.index:找出某个元素的索引位置:x.index(2)
=> 1

四、字典
1.写法: d={'a':1,'b':2}

2.dict函数:将键值对转换成字典:
items=[('a',1),('b',2)]
d=dict(itmes)
=> d={'a':1,'b':2}

3.另一种创建方式:d=dict(a=1,b=2)
=> {'a':1,'b':2}

4.基本字典操作方法:
(1)求元素个数:len(d) => 2
(2)用键访问值:d['a'] => 1
(3)修改值:d['a']=3
(4)删除: del d['a']
(5)成员资格: 'a' in d

5.很有用的方法:格式化字符串
通常的字符串格式化:
'i am %s ' % 'vertor'
=> 'i am vertor'
而如果应字典格式化就可以实现类似.net中string.format()的功能了:
d={'name':'vertor','age'=20}
'i am %(name)s, and %(age)s years old' % d
=> i am vertor, and 20 years old.

6.clear:清除所有元素

7.浅复制(shallow copy)copy函数:
d={'name':'verter',age:20,friends:['ali','qq','baidu']}
d2=d.copy()
d2['name']='smith' #用新的值替换原来的值
d2['friends'].remove('qq') #修改原来的值
=>d2
=>{'name':'smith',age:20,friends:['ali','baidu']}
=>d
=>{'name':'verter',age:20,friends:['ali','baidu']}
可以看到,在副本中替换值不会影响到原始字典;而如果修改了副本,原始字典也会被修改。
如果要避免这种情况就需要用到深复制:deepcopy

8.深复制(deepcopy):deepcopy函数

9.fromkeys:使用给定的键建立新的字典
{}.fromkeys(['name','age'])
=>{'name':None,'age':None}
dict.fromkeys(['name','age'])
=>{'name':None,'age':None}
dict.fromkeys(['name','age'],'verter')
=>{'name':'verter','age':'verter'}

10.get:另一种用键访问元素值的方法
d={'name':'verter','age':20}
=>d.get('name')
=>'verter'
=>d.get('friends')
=>None
注意:get与d['friends']的区别是后者会抛出KeyError异常,而get不会,他只是返回None.

11.has_key:
d={'name':'verter','age':20}
=>d.has_key('name')
=>True
注意:python3抛弃了这个API.

12.items和iteritems
(1)items将字典所有以<strong>列表</strong>的形式返回。
d={'name':'verter','age':20}
=>d.items()
=>[('name', 'verter'), ('age', 20)]
(2)iteritems作用大致相同,不过它是返回一个迭代器对象而不是列表
d={'name':'verter','age':20}
=>it=d.iteritems()
=>list(it)
=>[('name', 'verter'), ('age', 20)]
注意:在python3.0中将iteritems私有化了,变成了__iter__(),不知何故,难道这个功能太蛋疼,被抛弃了?

13.keys和iterkeys
d={'name':'verter','age':20}
=>for k in x.keys(): print(k)
=>'name'
=>'age'
同理:iterkeys返回迭代器,并且也被python3.0抛弃了,不再提供此方法了。

14.pop:返回对应键,并将他从字典中移除
d.pop('name')
=>'verter'
=>d
=>{'age':20}

15.popitem:不带参数,弹出一个随机元素。
d.popitem()
=>{'name','verter'}
这个对事先不知道键的情况下很有用。

16.setdefault:设置默认值。

17.update:利用一个字段更新另外一个字典,当然是更新对应键的值
d={'name':'verter','age':20}
=>d2={'name':'verter2'}
=>d.update(d2)
=>d
=>{'name':'verter2','age':20}

18.values和itevalues
(1)values:已列表形式返回字典中的值
(2)itervalues:返回值的迭代器
注意:python3.0还是抛弃了这个API.

转自:http://www.deepleo.com/archives/1603

Python数据结构:序列(列表[]、元组())与映射(字典{})语法总结的更多相关文章

  1. 孤荷凌寒自学python第八天 初识Python的序列之元组

    孤荷凌寒自学python第八天 Python的序列之元组 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) (同步音频笔记:https://www.ximalaya.com/keji/19103 ...

  2. Python数据结构之列表、元组及字典

    一位大牛Niklaus Wirth曾有一本书,名为<Algorithms+Data Structures=Programs>,翻译过来也就是算法+数据结构=程序.而本文就是介绍一下Pyth ...

  3. Python数据结构:列表、元组和字典

    在Python中有三种内建的数据结构——列表list.元组tuple和字典dict 列表中的项目包括在方括号中,项目之间用逗号分割 元组和列表十分类似,只不过元组和字符串一样是不可变的 即你不能修改元 ...

  4. python笔记(1)--序列(列表 元组 range)

    一.序列分类 1.可变序列:list 2.不可变序列:tuple,range 二.序列公共操作方法 1.操作和返回值 其中s和t代表同类型序列:n,i,j,k为整数:x为任意类型. 序号 操作 结果 ...

  5. python基础(五)列表,元组,集合

    列表 在python中是由数个有序的元素组成的数据结构,每一个元素对应一个index索引来隐式标注元素在列表中的位置.是python中最常用的一种数据类型.需要注意的是列表中可以有重复相同的数据. 列 ...

  6. python数据类型:序列(字符串,元组,列表,字典)

    序列通常有2个特点: 1,可以根据索引取值 2,可以切片操作 字符串,元组,列表,字典,都可以看做是序列类型 我的操作环境:Ubuntu16.04+python2.7 一.字符串类型 >按索引获 ...

  7. Python数据结构:列表、字典、元组、集合

    列表:shoplist = ['apple', 'mango', 'carrot', 'banana']字典:di = {'a':123,'b':'something'}集合:jihe = {'app ...

  8. Python初学笔记列表&元组&字典

    一.从键盘获取 1 print("请输入") 2 username = input("姓名:") 3 age = input("年龄:") ...

  9. python学习之列表元组,字典

    list:元素性质可以不一致,元素还可以是list,可类似数组方法进行索引(也可以用负数索引,-1表示最后一个),可用.append('')进行动态增加,可用pop()删除最后一个或者pop(i)删除 ...

  10. Day2 - Python基础2 列表、字符串、字典、集合、文件、字符编码

    本节内容 列表.元组操作 数字操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 ...

随机推荐

  1. 洛谷P1331海战

    题目描述 在峰会期间,武装部队得处于高度戒备.警察将监视每一条大街,军队将保卫建筑物,领空将布满了F-2003飞机.此外,巡洋船只和舰队将被派去保护海岸线. 不幸的是因为种种原因,国防海军部仅有很少的 ...

  2. VMware下Linux配置局域网和外网访问

    我想尝试的是利用本机的ip+port来访问虚拟机上的web服务器,因为这样的话,我就能够将我的web服务器部署成为一个能让外网访问的服务器了,首先说下我的环境: 主机:系统win7,ip地址172.1 ...

  3. Error “can't use subversion command line client : svn” Probably the path to Subversion executable is wrong

    错误提示如图. 大概意思就是SVN路径不对 解决方法如下: 首先下载Subversion 1.8.13(1.8) 下载链接(https://www.visualsvn.com/downloads/) ...

  4. jquery validate 使用示范

    最近应公司要求做了一个jquery的示例文件,包括:模态窗口怎么实现:jquery validate下的校验:怎么做图片特效:怎么实现异步操作:实现图片上传剪切效果等很多特效: 这里把jquery校验 ...

  5. HDU 4758 Walk Through Squares( AC自动机 + 状态压缩DP )

    题意:给你两个串A,B, 问一个串长为M+N且包含A和B且恰好包含M个R的字符串有多少种组合方式,所有字符串中均只含有字符L和R. dp[i][j][k][S]表示串长为i,有j个R,在自动机中的状态 ...

  6. fragment中的WebView返回上一页

    public final class Text1Fm extends Fragment { static WebView mWeb; private View mContentView; privat ...

  7. android配置开发环境

    1.下载Java SE并安装. 下载地址:http://www.oracle.com/technetwork/java/javase/downloads/index.html 配置环境变量 我的电脑- ...

  8. token的作用

    token的作用 基于 Token 的身份验证方法 使用基于 Token 的身份验证方法,在服务端不需要存储用户的登录记录.大概的流程是这样的: 客户端使用用户名跟密码请求登录 服务端收到请求,去验证 ...

  9. ZooKeeper客户端 zkCli.sh 节点的配额设置

    首先使用 zkCli.sh 连接上ZooKeeper服务器 配额设置命令格式如下: setquota -n|-b val path -n:val设置子节点个数 -b:val设置节点的数据长度 如果我们 ...

  10. 【bzoj2732】[HNOI2012]射箭 二分+半平面交

    题目描述 给出二维平面上n个与y轴平行的线段,求最大的k,使得存在一条形如$y=ax^2+bx(a<0,b>0)$的抛物线与前k条线段均有公共点 输入 输入文件第一行是一个正整数N,表示一 ...