List

list的创建与检索

Python内置的一种数据类型是列表:list。list是一种有序的集合,可以随时添加和删除其中的元素。

构造list非常简单,直接用 [ ] 把list的所有元素都括起来,就是一个list对象。

Python是动态语言,所以list中包含的元素并不要求都必须是同一种数据类型,我们完全可以在list中包含各种数据:

例如:

>>> L = ['Michael', 100, True]

list索引从 0 开始,也就是说,第一个元素的索引是0,第二个元素的索引是1,以此类推。

若索引为如-1则会检索倒数第一个元素

列表生成式可以快速生成具有特征的列表:

>>> [x * x for x in range(1, 11) if x % 2 == 0]
[4, 16, 36, 64, 100]

list的添加与删除新元素

添加元素

list的append()方法总是把新的元素添加到 list 的尾部。

>>> L = ['Adam', 'Lisa', 'Bart']
>>> L.append('Paul')
>>> print(L)
['Adam', 'Lisa', 'Bart', 'Paul']

list的insert()方法,它接受两个参数,第一个参数是索引号,第二个参数是待添加的新元素:

>>> L = ['Adam', 'Lisa', 'Bart']
>>> L.insert(0, 'Paul')
>>> print(L)
['Paul', 'Adam', 'Lisa', 'Bart']

L.insert(0, 'Paul') 的意思是,'Paul'将被添加到索引为 0 的位置上(也就是第一个),而原来索引为 0 的Adam同学,以及后面的所有同学,都自动向后移动一位。

删除元素

list的pop()函数总是删掉list的最后一个元素,并且它还返回这个元素。

>>> L = ['Adam', 'Lisa', 'Bart', 'Paul']
>>> L.pop()
'Paul'
>>> print(L)
['Adam', 'Lisa', 'Bart']

但是pop()可以接受一个参数,例如pop(2)则是删除列表中第三个元素

list的remove() 函数用于移除列表中某个值的第一个匹配项。

remove()方法语法:

list.remove(obj)

注意:在循环中使用remove()时需要考虑如下问题:

例如在for循环中对原列表使用remove(),这样下一次循环时会跳过一次元素,因为刚刚移除元素之后,那个元素之后的元素下标会-1

解决办法:

在复制一个列表,例如   copy()方法可以复制一个列表:

for car in cars.copy():
cars.remove(car)

参数

  • obj -- 列表中要移除的对象。

实例:

>>> l=[1,2,1,3]
>>> l.remove(1)
>>> l
[2, 1, 3]

替换元素

对list中的某一个索引赋值,就可以直接用新的元素替换掉原来的元素,list包含的元素个数保持不变。

>>> L = ['Adam', 'Lisa', 'Bart']
>>> L[2] = 'Paul'
>>> print(L)
L = ['Adam', 'Lisa', 'Paul']

list.count()

该函数可计算某元素出现的次数

>>> list=[1,1,1,1,2,3,4,1,1]
>>> list.count(1)
6

Tuple

tuple的创建与检索

tuple是另一种有序的列表,中文翻译为“ 元组 ”。tuple 和 list 非常类似,但是,tuple一旦创建完毕,就不能修改了。

创建tuple和创建list唯一不同之处是用( )替代了[ ]。tuple没有 append()方法,也没有insert()和pop()方法。

获取 tuple 元素的方式和 list 是一模一样的,我们可以正常使用 t[0],t[-1]等索引方式访问元素,但是不能赋值成别的元素。

>>> t = ('Adam', 'Lisa', 'Bart')

tuple和list一样,可以包含 0 个、1个和任意多个元素。因为()既可以表示tuple,又可以作为括号表示运算时的优先级,

所以定义单元素的tuple有歧义,所以 Python 规定,单元素 tuple 要多加一个逗号“,”。

>>> t = (1,)
>>> print(t)
(1,)

同时,tuple的元素可以是list,而list元素是可变的

>>> t = ('a', 'b', ['A', 'B'])
>>> L = t[2]
>>> L[0] = 'X'
>>> L[1] = 'Y'
>>> print(t)
('a', 'b', ['X', 'Y'])

Dict

dict的特点:

dict的第一个特点是查找速度快,无论dict有10个元素还是10万个元素,查找速度都一样。而list的查找速度随着元素增加而逐渐下降。

不过dict的查找速度快不是没有代价的,dict的缺点是占用内存大,还会浪费很多内容,list正好相反,占用内存小,但是查找速度慢。

由于dict是按 key 查找,所以,在一个dict中,key不能重复。

dict的第二个特点就是存储的key-value序对是没有顺序的!

dict的创建与检索

我们可以使用dict将一个key值与value组合起来,这样方便进行查找key的value值

d = {
'Adam': 95,
'Lisa': 85,
'Bart': 59
}

dict就是通过 key来查找 value。

花括号 {} 表示这是一个dict,然后按照 key: value, 写出来即可。

我们可以简单地使用 d[key] 的形式来查找对应的 value,这和 list 很像

>>> print(d['Adam'])
95
>>> print(d['Paul'])
Traceback (most recent call last):
File "index.py", line 11, in <module>
print (d['Paul'])
KeyError: 'Paul'

注意: 通过 key 访问 dict 的value,只要 key 存在,dict就返回对应的value。如果key不存在,会直接报错:KeyError。

要避免 KeyError 发生,有两个办法:

一是先判断一下 key 是否存在,用 in 操作符:

if 'Paul' in d:
print(d['Paul'])

二是使用dict本身提供的一个 get 方法,在Key不存在的时候,返回None:

>>> print(d.get('Bart'))
59
>>> print(d.get('Paul'))
None

dict数据的更新

若key值不存在,则向其加入新的key-value

d = {
'Adam': 95,
'Lisa': 85,
'Bart': 59
}
>>> d['Paul'] = 72
>>> print(d)
{'Lisa': 85, 'Paul': 72, 'Adam': 95, 'Bart': 59}

若key值存在,则更新数据

>>> d['Bart'] = 60
>>> print(d)
{'Lisa': 85, 'Paul': 72, 'Adam': 95, 'Bart': 60}

Set

什么是set

dict的作用是建立一组 key 和一组 value 的映射关系,dict的key是不能重复的。

有的时候,我们只想要 dict 的 key,不关心 key 对应的 value,目的就是保证这个集合的元素不会重复,这时,set就派上用场了。

set 持有一系列元素,这一点和 list 很像,但是set的元素没有重复,而且是无序的,这点和 dict 的 key很像。

set的创建与访问

创建 set 的方式是调用 set() 并传入一个 list,list的元素将作为set的元素:

>>> s = set(['Adam', 'Lisa', 'Bart', 'Paul'])

由于set存储的是无序集合,所以我们没法通过索引来访问。

访问 set中的某个元素实际上就是判断一个元素是否在set中。

>>> 'Bart' in s
True

注意:set中的元素区分大小写

set的特点

set的内部结构和dict很像,唯一区别是不存储value,因此,判断一个元素是否在set中速度很快。

set存储的元素和dict的key类似,必须是不变对象,因此,任何可变对象是不能放入set中的。

set元素的更新

由于set存储的是一组不重复的无序元素,因此,更新set主要做两件事:

一是把新的元素添加到set中,二是把已有元素从set中删除。

添加元素时,用set的add()方法:

>>> s = set([1, 2, 3])
>>> s.add(4)
>>> print(s)
set([1, 2, 3, 4])

删除set中的元素时,用set的remove()方法:

>>> s = set([1, 2, 3, 4])
>>> s.remove(4)
>>> print(s)
set([1, 2, 3])

如果删除的元素不存在set中,remove()会报错:

>>> s = set([1, 2, 3])
>>> s.remove(4)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
KeyError: 4

所以用add()可以直接添加,而remove()前需要判断。

以上就是对于python中的list,tuple,dict和set的一些总结。

Python中的list,tuple,dict和set的更多相关文章

  1. python中的list,tuple,dict,set简介---陈雨童

    变量和对象 变量把对象和自己连接起来(指针连接对象空间),引用建立了变量和对象之间的映射关系,这就是引用.引用完成,就实现了赋值.变量通过对象的内存地址指向对象,类似于软链接 将变量a赋值给变量b,其 ...

  2. Python中的list,tuple,dict,set

    list=[11,"aa",33] 增: list.insert(1,"asas") list.append(22) 删: list.pop() list.po ...

  3. Python中的List,Tuple,Dic,Set

    Python中的List,Tuple,Dic,Set List定义 序列是Python中最基本的数据结构.序列中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推 ...

  4. python中list、tuple、dict、set的使用

    1.list列表 list是一种可变的,有序的列表,可以随时添加和删除其中的元素. 其格式如下:list-name=[element1,element2,....] >>> nums ...

  5. python学习中,list/tuple/dict格式化遇到的问题

    昨天上了python培训的第一课,学习了基础知识.包括类型和赋值,函数type(),dir(),id(),help()的使用,list/tuple/dict的定义以及内置函数的操作,函数的定义,控制语 ...

  6. Python:数据结构(list, tuple, Dict & Set)

    list: Python中内置的有序数据结构,即数组.由于Python是动态语言,因此数组元素的类型没有限定. classmates = [“Michael”, “David”,”Bob”,”Trac ...

  7. python学习笔记(二)python基础知识(list,tuple,dict,set)

    1. list\tuple\dict\set d={} l=[] t=() s=set() print(type(l)) print(type(d)) print(type(t)) print(typ ...

  8. Python中的元组(tuple)、列表(list)、字典(dict)

    -------------------------------更新中-------------------------------------- 元组(tuple): 元组常用小括号表示,即:(),元 ...

  9. 代码与图详解性能之Python集合类型(list tuple dict set generator)

    Python内嵌的集合类型有list.tuple.set.dict. 列表list:看似数组,但比数组强大,支持索引.切片.查找.增加等功能. 元组tuple:功能跟list差不多,但一旦生成,长度及 ...

随机推荐

  1. JavaScript 中表达式和语句的区别

    1.语句和表达式 JavaScript中的表达式和语句是有区别的.一个表达式会产生一个值,它可以放在任何需要一个值的地方,比如,作为一个函数调用的参数.下面的每行代码都是一个表达式: myvar3 + ...

  2. 洛谷P3567 [POI2014]KUR-Couriers 主席树

    挺裸的,没啥可讲的. 不带修改的主席树裸题 Code: #include<cstdio> #include<algorithm> using namespace std; co ...

  3. 路飞学城Python-Day14(practise)

    本章总结 练习题 1.logging模块有几个日志级别? 5个,按级别从高到低分别是 CRITICAL(灾难)>ERROR(错误)>WARNING(警示)>INFO(信息)>D ...

  4. ajax错误信息

    XMLHttpRequest.status状态码 1xx-信息提示 这些状态代码表示临时的响应.客户端在收到常规响应之前,应准备接收一个或多个1xx响应. 100-继续. 101-切换协议. 2xx- ...

  5. java后台生成图片二维码

    controller: /** * 获取登录的验证码 * @param request * @param response */ public void getLoginCode(HttpSessio ...

  6. caioj 1152 快速求模 (快速幂)

    (1)开long long,不然中间结果会溢出 (2)注意一开始的初始化,保险一点. #include<cstdio> #include<cctype> #include< ...

  7. 紫书 例题11-9 UVa 1658 (拆点+最小费用流)

    这道题要求每个节点只能经过一次,也就是结点容量为1, 要拆点, 拆成两个点, 中间连一条弧容量为1, 费用为0. 因为拆成两个点, 所以要经过原图中的这个节点就要经过拆成的这两个点, 又因为这两个点的 ...

  8. Linux shell 内部变量

    1 TMOUT 来自bash的解释: If set to a value greater than zero, TMOUT is treated as the default timeout for ...

  9. Cannot set web app root system property when WAR file is not expanded

    Cannot set web app root system property when WAR file is not expanded 在tomcat下面可以,在weblogic下面不行的处理方法 ...

  10. HDOJ 5296 Annoying problem LCA+数据结构

    dfs一遍得到每一个节点的dfs序,对于要插入的节点x分两种情况考虑: 1,假设x能够在集合中的某些点之间,找到左边和右边距离x近期的两个点,即DFS序小于x的DFS序最大点,和大于x的DFS序最小的 ...