Python档案袋(列表、元组、字典、集合 )
列表
可以同名,有序(通过下标可找到)
取值:
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档案袋(列表、元组、字典、集合 )的更多相关文章
- python中列表 元组 字典 集合的区别
列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计 ...
- **python中列表 元组 字典 集合
列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. 1.列表 列表是以方括号“[]”包围的数据集合,不同成员以“,”分隔. 列表的特 ...
- python 中列表 元组 字典 集合的区别
先看图片解释 (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计过去一周我们买过的东西,把这些东西列出来,就是清单.由于我们买一种东西可能不止一次,所以清单中是允许有重复 ...
- python的列表元组字典集合比较
定义 方法 列表 可以包含不同类型的对象,可以增减元素,可以跟其他的列表结合或者把一个列表拆分,用[]来定义的 eg:aList=[123,'abc',4.56,['inner','list'],7- ...
- python3笔记十八:python列表元组字典集合文件操作
一:学习内容 列表元组字典集合文件操作 二:列表元组字典集合文件操作 代码: import pickle #数据持久性模块 #封装的方法def OptionData(data,path): # ...
- python_列表——元组——字典——集合
列表——元组——字典——集合: 列表: # 一:基本使用# 1.用途:存放多个值 # 定义方式:[]内以逗号为分隔多个元素,列表内元素无类型限制# l=['a','b','c'] #l=list([' ...
- python的学习笔记01_4基础数据类型列表 元组 字典 集合 其他其他(for,enumerate,range)
列表 定义:[]内以逗号分隔,按照索引,存放各种数据类型,每个位置代表一个元素 特性: 1.可存放多个值 2.可修改指定索引位置对应的值,可变 3.按照从左到右的顺序定义列表元素,下标从0开始顺序访问 ...
- Python 列表&元组&字典&集合
列表(list) 有序性,可存储任意类型的值 通过偏移存取,支持索引来读取元素,第一个索引为0 ,倒数第一个索引为-1 可变性 ,支持切片.合并.删除等操作 可通过索引来向指定位置插入元素 可通过po ...
- Python之列表&元组&字典
今天学习了Python的基本数据类型,做以下笔记,以备查用. 一.列表 列表的常用方法: 1.append()方法 def append(self, p_object): # real signatu ...
- Day 07 数据类型的内置方法[列表,元组,字典,集合]
数据类型的内置方法 一:列表类型[list] 1.用途:多个爱好,多个名字,多个装备等等 2.定义:[]内以逗号分隔多个元素,可以是任意类型的值 3.存在一个值/多个值:多个值 4.有序or无序:有序 ...
随机推荐
- 中国居民18位身份证号验证方法,Java算法实现
public static boolean validate18Idcard(String idcard){ if(idcard == null ) { return false; } if(idca ...
- js中的严格模式和非严格模式的比较
前言 es5的严格模式是采用具有限制性JavaScript变体的一种方式,从而使代码显示地脱离'懒散模式/非严格模式' 严格模式 严格模式通过抛出错误来消除一些原有静默错误 严格模式修复了一些导致Ja ...
- Cocos动作执行时,同时执行完毕再进行下一步的方式
在js中,runAction是统一保存起来等单个文件运行完了再统一进行回调运行的,所以如果想在动作执行完毕之后调用某个函数,那这个函数就应该存在于回调函数中,不会就不能同步了
- 基于 EntityFramework、Autofac 的 UnitOfWork 框架(一)
之前公司项目参考 NopCommerce 开发了一套系统,但是不支持 UnitOfWork,最近想开发新的项目,所以就基于原有的基础上又添加 UnitOfWork 支持,由于目前正在逐步完善中,所以可 ...
- eclipse 开发环境问题
1.jdk安装,环境变量设置.主要有两个: JAVA_HOME C:\Program Files\Java\jre7 JRE_HOME C:\Program Files\Java\jre7 2 ...
- <算法图解>读书笔记:第1章 算法简介
阅读书籍:[美]Aditya Bhargava◎著 袁国忠◎译.人民邮电出版社.<算法图解> 第1章 算法简介 1.2 二分查找 一般而言,对于包含n个元素的列表,用二分查找最多需要\(l ...
- C++日志打印
C++日志打印: %d 十进制有符号整数 %u 十进制无符号整数 %f 浮点数 %s 字符串 % ...
- Firefox 的兼容问题
Firefox (火狐) 坑 一, css 文本溢出省略号 单行 : overflow:hidden; text-overflow:ellipsis; white-space:nowrap 多行 : ...
- 机器学习(六)K-means聚类、密度聚类、层次聚类、谱聚类
本文主要简述聚类算法族.聚类算法与前面文章的算法不同,它们属于非监督学习. 1.K-means聚类 记k个簇中心,为\(\mu_{1}\),\(\mu_{2}\),...,\(\mu_{k}\),每个 ...
- linux学习:用户管理
一.管理用户(user) 主要工具命令 useradd 注:添加用户 adduser 注:添加用户 passwd 注:为用户设置密码 usermod 注:修改用户命令,可以通 ...