列表

可以同名,有序(通过下标可找到)

取值:

 1 #声明列表
2 listx=["L0","L1","L2",33,"L4"]
3 print(listx) #输出:['L0', 'L1', 'L2', 33, 'L4']
4 print(len(listx)) #统计总个数,输出:5
5 print(listx[1]) #下标取值,输出:L1
6 print(listx[0:2])#切片区间为:[0,2),输出:['L0', 'L1']
7 print(listx[:2])#输出:['L0', 'L1']
8 print(listx[-1])#倒数第一个,输出:L4
9 print(listx.index("L1"))#查找内容的下标,查找到第一个,输出:1
10 print(listx.count("L4")) #统计值为L4的个数 输出:1

遍历:

1 #声明列表
2 listx=["L0",[11,22,33],"L1"]
3
4 print(type(listx)) #输出类型为:<class 'list'>
5
6 for i in listx:
7 print(i) #输出:L0 [11, 22, 33] L1

修改:

 1 #声明列表
2 listx=["L0","L1","L1"]
3
4 listx[2]="L1.1" #修改值
5 listx.append("L2") #追加,结尾添加
6 listx.insert(1,"L1.0") #插入,参数(位置,内容)
7
8 listx.reverse()#反转
9 listx.sort()#排序
10
11 print(listx) #输出:['L0', 'L1', 'L1.0', 'L1.1', 'L2']

删除:

1 #声明列表
2 listx=["L0","L1","L2",33,"L4"]
3 listx.remove("L2") #删除,以内容
4 del listx[0] #删除,以下标
5 listx.pop(0) #删除,以下标,默认删除最后一个
6
7 #listx.clear() #清空列表
8 print(listx) #输出:[33, 'L4']

利用for循环的列表生成:

#生成列表,for循环的值传递到前面的算式进行值的修改
listx=[i*10 for i in range(10)] print(listx)#输出:[0, 10, 20, 30, 40, 50, 60, 70, 80, 90]

列表排序:

#排序
listx=[20,100,66,99,11]
print(sorted(listx)) #排序,输出:[11, 20, 66, 99, 100]

列表合并:

list1=[11,22]
list2=[99,88] list1.extend(list2) #扩展
print(list1) #输出:[11, 22, 99, 88]

列表的一一对应:

1 #一 一对应
2 list1=[11,22,33,88]
3 list2=["cc","bb","aa","dd"]
4 res=zip(list1,list2)#变成一个迭代器
5 print(next(res)) #输出:(11, 'cc')

字符串与列表的转换:

函数eval()可以将格式化的字符串转换为列表、字典等数据类型

1 a="[11,33,55]"
2
3 #转换函数
4 aa=eval(a)
5 print(aa[2]) #输出:55
6
7 #进列表转换为字符串
8 print(type(str(a))) #输出:<class 'str'>

浅copy,只copy第一层:

 1 #声明列表
2 listx=["L0",[11,22,33],"L1"]
3
4 list2=listx.copy()#浅copy,只copy第一层
5
6 list2[0]="L0000" #只改自己
7 list2[1][2]=3333333333 #一改全改
8
9 print(listx)#输出:['L0', [11, 22, 3333333333], 'L1']
10 print(list2)#输出:['L0000', [11, 22, 3333333333], 'L1']

深copy,独立分配内存空间

 1 import copy
2
3 #声明列表
4 listx=["L0",[11,22,33],"L1"]
5
6 list2=copy.deepcopy(listx)#深copy,独立分配内存空间
7
8 list2[0]="L0000" #只改自己
9 list2[1][2]=3333333333 #只改自己
10
11 print(listx)#输出:['L0', [11, 22, 33], 'L1']
12 print(list2)#输出:['L0000', [11, 22, 3333333333], 'L1']

元组:

值不可更改,值可重复,有序(通过下标可找到)

 1 #声明元组
2 va=("dongxiaodong","东小东","222","dong","dong",("11",22,33))
3
4 print(type(va))#类型,输出:<class 'tuple'>
5
6 print(len(va)) #总个数,输出:6
7
8 print(va.count("dong")) #统计某个值的个数 输出:2
9
10 print(va.index("dong")) #查询值的下标 输出:3
11
12 print(va[1]) #下标取值,输出:东小东

字典:

无序,键不可重复

 1 #创建字典方法1
2 va={"v1":"111","v2":"222",33:"333"}
3
4 #创建字典方法2
5 va2=dict.fromkeys(["v1","v2",33],"xxxxx") #创建不同的键对应一个值
6 print(va2) #输出:{'v1': 'xxxxx', 'v2': 'xxxxx', 33: 'xxxxx'}
7
8
9 print(va[33]) #通过键取值,不存在则报错
10 print(va.get(44)) #存在则返回值,不存在则返回None
11
12 print("v1" in va) #判断键是否存在字典中
13
14 va["v1"]="1x1x1x1" #修改
15
16 va["v3"]="xxxx333333" #添加
17
18 va.update({"v1":"vvvvv11111","v4":"444444"}) #键存在则更新值,键不存在则创建
19
20 print(va.items()) #输出:dict_items([('v1', 'vvvvv11111'), ('v2', '222'), (33, '333'), ('v3', 'xxxx333333'), ('v4', '444444')])
21
22
23
24 #del va["v2"] #删除某对
25 #va.pop("v3") #删除某对
26
27 #va.popitem() #随机删除一对,默认删除最后一对
28
29 #del va #删除所有
30
31 print(va) #打印所有
32
33
34 #字典循环打印方法1
35 #效率较高,推荐
36 #循环键
37 for i in va:
38 print(i,va[i])
39
40 #字典循环打印方法2
41 #循环键值
42 for k,v in va.items():
43 print(k,v)

字典的排序

 1 #排序
2 a={"5":55555,"2":88888,"32":22222}
3
4 #按键排序,键的数据类型必须一样
5 #输出:[('2', 88888), ('32', 222222), ('5', 55555)]
6 print(sorted(a.items()))
7
8 #按值排序,值的数据类型必须一样
9 #输出:[('32', 22222), ('5', 55555), ('2', 88888)]
10 print(sorted(a.items(),key=lambda x:x[1]))

集合

值不可重复,重复则保留其中一个,无序,因为集合是无序的,所以取值一般都是经过for循环,而不会使用下标取值

 1 listx1=set(["10",10,11,12,12])
2 print(listx1) #输出:{10, 11, 12, '10'}
3
4 listx2=set([10,100])
5
6 #交集
7 #方法1:
8 print(listx1.intersection(listx2)) #输出:{10}
9 #方法2:
10 print(listx1 & listx2)#输出:{10}
11
12 #并集
13 #符号为:|
14 print(listx1.union(listx2)) #输出:{100, 10, 11, 12, '10'}
15
16 #差集
17 #符号为: -
18 # 在listx1中有,但listx2中没有的,参数可有对换
19 print(listx1.difference(listx2)) #{11, 12, '10'}
20
21 #子集
22 #listx2w是不是listx1的子集,返回bool
23 print(listx2.issubset(listx1)) #输出:False
24
25 #父集
26 #listx1是不是listx2的父集,返回bool
27 print(listx1.issuperset(listx2)) #输出:False
28
29 #对称差集
30 #在并集的基础上将两个集合都有的元素去掉
31 print(listx2 ^ listx1) #输出:{100, 11, 12, '10'}
32
33 listx2.add("dongxiaodong") #添加一项
34 listx2.update(["dong1","dong2"]) #添加多项
35
36 listx2.remove("dong1") #删除一项,不存在会报错
37 listx2.discard("dong1")#删除一项,不存在会返回None
38
39 print(len(listx2)) #打印长度
40
41 print(listx2)

Python档案袋(列表、元组、字典、集合 )的更多相关文章

  1. python中列表 元组 字典 集合的区别

    列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计 ...

  2. **python中列表 元组 字典 集合

    列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. 1.列表 列表是以方括号“[]”包围的数据集合,不同成员以“,”分隔. 列表的特 ...

  3. python 中列表 元组 字典 集合的区别

    先看图片解释 (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计过去一周我们买过的东西,把这些东西列出来,就是清单.由于我们买一种东西可能不止一次,所以清单中是允许有重复 ...

  4. python的列表元组字典集合比较

    定义 方法 列表 可以包含不同类型的对象,可以增减元素,可以跟其他的列表结合或者把一个列表拆分,用[]来定义的 eg:aList=[123,'abc',4.56,['inner','list'],7- ...

  5. python3笔记十八:python列表元组字典集合文件操作

    一:学习内容 列表元组字典集合文件操作 二:列表元组字典集合文件操作 代码: import pickle  #数据持久性模块 #封装的方法def OptionData(data,path):    # ...

  6. python_列表——元组——字典——集合

    列表——元组——字典——集合: 列表: # 一:基本使用# 1.用途:存放多个值 # 定义方式:[]内以逗号为分隔多个元素,列表内元素无类型限制# l=['a','b','c'] #l=list([' ...

  7. python的学习笔记01_4基础数据类型列表 元组 字典 集合 其他其他(for,enumerate,range)

    列表 定义:[]内以逗号分隔,按照索引,存放各种数据类型,每个位置代表一个元素 特性: 1.可存放多个值 2.可修改指定索引位置对应的值,可变 3.按照从左到右的顺序定义列表元素,下标从0开始顺序访问 ...

  8. Python 列表&元组&字典&集合

    列表(list) 有序性,可存储任意类型的值 通过偏移存取,支持索引来读取元素,第一个索引为0 ,倒数第一个索引为-1 可变性 ,支持切片.合并.删除等操作 可通过索引来向指定位置插入元素 可通过po ...

  9. Python之列表&元组&字典

    今天学习了Python的基本数据类型,做以下笔记,以备查用. 一.列表 列表的常用方法: 1.append()方法 def append(self, p_object): # real signatu ...

  10. Day 07 数据类型的内置方法[列表,元组,字典,集合]

    数据类型的内置方法 一:列表类型[list] 1.用途:多个爱好,多个名字,多个装备等等 2.定义:[]内以逗号分隔多个元素,可以是任意类型的值 3.存在一个值/多个值:多个值 4.有序or无序:有序 ...

随机推荐

  1. brew本地安装包

    brew --cache # 输出本地缓存 一般位置 ~/Library/Caches/Homebrew # 将下载下来文件mv到缓存路径 download目录 # 重命名成没有下载下来的文件名 xx ...

  2. Asp.Net Core 使用Swashbuckle.AspNetCore 生成API文档

    详情参考:https://www.cnblogs.com/morang/p/9741511.html github地址:https://github.com/yimogit/moxy.blogs/tr ...

  3. Beginning Python Games Development

    Like music and movies, video games are rapidly becoming an integral part of our lives. Over the year ...

  4. Django缓存机制

    缓存介绍 在动态网站中,用户所有的请求,服务器都会去数据库中进行相应的增删改查,渲染模板,执行业务逻辑,最后生成用户看到的页面. 当一个网站的用户访问量很大的时候,每一次的后台操作,都会消耗很多的服务 ...

  5. 一小时学会ECMAScript6新特性(一)

    ECMAScript 简介 简称es,是一套标准,javascript就是使用这套标准的语言.主流的浏览器使用的是ECAMScript5,ECAMScript6(ECAMScript2015)是一涛新 ...

  6. Y1S002 xshell脚本编写示意

    SecureCRT可以自己录制脚本,非常的方便:但是考虑到CRT收费,所以不计划把CRT作为使用的终端. vbs脚本(test.vbs): Sub main xsh.Screen.Synchronou ...

  7. promisify,promisifyAll,promise.all实现原理

    1.promisify function toPrimisify (fn){ return function (...args){      return new Promise(function(r ...

  8. 原生JS制作简易Tabs组件

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. python_非阻塞套接字及I/O流

    http://www.cnblogs.com/lixy-88428977/p/9638949.html 首先,我们要明确2个问题: 普通套接字实现的服务端有什么缺陷吗? 有,一次只能服务一个客户端! ...

  10. Visual Studio2012 添加服务引用时,生成基于任务操作不可用原因

    今天在添加服务引用时,发现 单选按钮 ”生成基于任务操作“不可用,原因项目选择的.net frame是3.5,调整为.net 4.5或.net4.6即可. 原因:.net4.5以下的环境不支持.