1、元组

特点:一旦创建,内容不可修改,又叫只读列表

 a= ('wang','zhang','zhao')
print(a.count('zhao'))
print(a.index('wang'))

2、列表

name = ["wang","zhao","zhang"]

  切片:取多个元素

 name = ["wang","zhao","zhang","lili","hao"]
print(name[0:3])
print(name[0:-1])
print(name[0:])
print(name[:])
print(name[::2])
运行结果:
['wang', 'zhao', 'zhang']
['wang', 'zhao', 'zhang', 'lili']
['wang', 'zhao', 'zhang', 'lili', 'hao']
['wang', 'zhao', 'zhang', 'lili', 'hao']
['wang', 'zhang', 'hao']

  追加

name.append('张三')
print(name)
运行结果:
['wang', 'zhao', 'zhang', 'lili', 'hao', '张三']

  插入

 name.insert(0,'赵四')
print(name)
运行结果:
['赵四', 'wang', 'zhao', 'zhang', 'lili', 'hao', '张三']

  修改

name[0] = 'zhaosi'
print(name)
运行结果:
['zhaosi', 'wang', 'zhao', 'zhang', 'lili', 'hao', '张三']

  删除

name.remove('zhaosi')
print(name)
运行结果:
['wang', 'zhao', 'zhang', 'lili', 'hao', '张三']
del name[1]
print(name)
运行结果:
['wang', 'zhang', 'lili', 'hao', '张三']

  扩展

name = ['zhaosi', 'wang', 'zhao', 'zhang', 'lili', 'hao', '张三']
name1 = ['小明','小张','张三']
print(name)
name.extend(name1)
print(name)
运行结果: 
['zhaosi', 'wang', 'zhao', 'zhang', 'lili', 'hao', '张三']
['zhaosi', 'wang', 'zhao', 'zhang', 'lili', 'hao', '张三', '小明', '小张', '张三']

  拷贝

第一层的不会变,后面的跟着变,列表及字典的第一级修改后,copy的内容不会变,下一级的copy值会跟着变,共享空间,指针

print(name)
name1 = name.copy()
print(name1)
name[0]='赵四'
print(name)
print(name1)
运行结果:
['zhaosi', 'wang', 'zhao', 'zhang', 'lili', 'hao', '张三']
['zhaosi', 'wang', 'zhao', 'zhang', 'lili', 'hao', '张三']
['赵四', 'wang', 'zhao', 'zhang', 'lili', 'hao', '张三']
['zhaosi', 'wang', 'zhao', 'zhang', 'lili', 'hao', '张三']

  统计

print(name.count('zhang'))

  排序

name.sort()#正向排序
print(name)
name.reverse()#反向排序
print(name)

  获取下标

print(name.index('张三'))
运行结果:1

3、字典

特性:无序的;唯一key值,天生去重

student={
'stu1101':{'name':'张三','age':22},
'stu1102':{'name':'李四','age':22},
'stu1103':{'name':'王二','age':25},
}

增加

 student={
'stu1101':{'name':'张三','age':22},
'stu1102':{'name':'李四','age':22},
'stu1103':{'name':'王二','age':25},
}
student['stu1104']='王三'
print(student)
运行结果:
{'stu1101': {'name': '张三', 'age': 22}, 'stu1102': {'name': '李四', 'age': 22}, 'stu1103': {'name': '王二', 'age': 25}, 'stu1104': '王三'}

修改

 student={
'stu1101':{'name':'张三','age':22},
'stu1102':{'name':'李四','age':22},
'stu1103':{'name':'王二','age':25},
}
student['stu1103']['name']='王三'
student['stu1101']={'name':'张四','age':23}
print(student)
运行结果:
{'stu1101': {'name': '张四', 'age': 23}, 'stu1102': {'name': '李四', 'age': 22}, 'stu1103': {'name': '王三', 'age': 25}}

删除

pop():删除指定键值对应的数据

popitem():随机删除字典中的一对键和值

del student['stu1101']#删除
print(student)
student.pop('stu1101')#删除
print(student)
student.popitem()#随机删除
print(student)

查找

student={
'stu1101':{'name':'张三','age':22},
'stu1102':{'name':'李四','age':22},
'stu1103':{'name':'王二','age':25},
'stu1105':{'name':'王si','age':26},
'stu1104':{'name':'王一','age':23},
'stu1106':{'name':'王sd','age':23},
}
print('stu1101' in student)
print(student['stu1101'])#key不存在会报错
print(student.get('stu1101'))#key不存在返回None
print(student.get('stu1110'))
运行结果:
True
{'name': '张三', 'age': 22}
{'name': '张三', 'age': 22}
None

  合并更新

student={
'stu1101':{'name':'张三','age':22},
'stu1102':{'name':'李四','age':22},
'stu1103':{'name':'王二','age':25},
'stu1105':{'name':'王si','age':26},
'stu1104':{'name':'王一','age':23},
'stu1106':{'name':'王sd','age':23},
}
student2 = {
"stu1101":{"name":"wangdawei","age":22,"TEL":1581033},
"stu1110":"zhaoyazhi"
}
student.update(student2)
print(student)
运行结果:
{'stu1101': {'name': 'wangdawei', 'age': 22, 'TEL': 1581033}, 'stu1102': {'name': '李四', 'age': 22}, 'stu1103': {'name': '王二', 'age': 25},
'stu1105': {'name': '王si', 'age': 26}, 'stu1104': {'name': '王一', 'age': 23}, 'stu1106': {'name': '王sd', 'age': 23}, 'stu1110': 'zhaoyazhi'}

其他

print(student.keys())#返回可遍历的KEY值
print(student.values())#返回可遍历的value值
print(student.items())#返回可遍历的KEY,value值
for key in student: 
  print(key,info[key])
for k,v in student.items(): #会先把dict转成list,数据里大时莫用
  print(k,v)

4、集合 

集合是一个无序的,数据不重复的数据组合,作用如下:

  • 去重,把一个列表变成集合就自动去重了
  • 测试两组数据之间的交集、并集、差集等关系

定义:

a = {1,3,5,7,10}
b = {2,3,4,5,6,8} #交集
print(a & b)
print(a.intersection(b))
print(a.intersection_update(b)) #等价于a = a.intersection(b)
print(a)
#差集
a = {1,3,5,7,10} 
b = {1,3,5}
print(a-b)
print(a.difference(b))
运行结果:
{10, 7}
{10, 7} #并集
print(a | b)
print(a.union(b))
运行结果:
{1, 2, 3, 4, 5, 6, 7, 8, 10}
{1, 2, 3, 4, 5, 6, 7, 8, 10} #对称差集
print(a ^ b)
print(a.symmetric_difference(b))#去掉公共部分
运行结果:
{1, 2, 4, 6, 7, 8, 10}
{1, 2, 4, 6, 7, 8, 10}

  

5、join()函数

join():    连接字符串数组。将字符串、元组、列表中的元素以指定的字符(分隔符)连接生成一个新的字符串

语法:  'sep'.join(seq)

参数说明
sep:分隔符。可以为空
seq:要连接的元素序列、字符串、元组、字典
上面的语法即:以sep作为分隔符,将seq所有的元素合并成一个新的字符串

返回值:返回一个以分隔符sep连接各个元素后生成的字符串

student={
'stu1101':{'name':'张三','age':22},
'stu1102':{'name':'李四','age':22},
'stu1103':{'name':'王二','age':25},
}
list=['wang','zhao']
print(''.join(list))
print('.'.join(list))
print('.'.join(student))
运行结果:
wangzhao
wang.zhao
stu1101.stu1102.stu1103

  

python之路3-元组、列表、字典、集合的更多相关文章

  1. python基础一 -------如何在列表字典集合中根据条件筛选数据

    如何在列表字典集合中根据条件筛选数据 一:列表 先随机生成一个列表,过滤掉负数 1,普通for循环迭代判断 2,filter()函数判断,filter(函数,list|tuple|string) fi ...

  2. python数据类型详解及列表字典集合推导式详解

    一.运算符 Python语言支持以下类型的运算符: 算术运算符 如: #!/usr/bin/env python # -*- coding:utf-8 -*- a = 5 b = 6 print(a ...

  3. Python之旅Day2 元组 字符串 字典 集合

    元组(tuple) 元组其实跟列表差不多,也是存一组数,与列表相比,元组一旦创建,便不能再修改,所以又叫只读列表. 语法: names = ("Wuchunwei","Y ...

  4. Python之路-基础数据类型之字典 集合

    字典的定义-dict 字典(dict)是python中唯⼀的⼀个映射类型.他是以{ }括起来的键值对组成,字典是无序的,key是不可修改的.dic = {1:'好',2:'美',3:'啊'} 字典的操 ...

  5. python中元组/列表/字典/集合

    转自:https://blog.csdn.net/lobo_seeworld/article/details/79404566

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

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

  7. Python 高效编程技巧实战(2-1)如何在列表,字典, 集合中根据条件筛选数据

    Python 高效编程技巧实战(2-1)如何在列表,字典, 集合中根据条件筛选数据 学习目标 1.学会使用 filter 借助 Lambda 表达式过滤列表.集合.元组中的元素: 2.学会使用列表解析 ...

  8. python :列表 字典 集合 类 ----局部变量可以改全局变量

    #列表 字典 集合 类 ----局部变量可以改全局变量,除了整数和字符串 names=["alex","jack","luck"] def ...

  9. python学习笔记(一)元组,序列,字典

    python学习笔记(一)元组,序列,字典

  10. Python基础2 列表 字典 集合

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

随机推荐

  1. 杂牌机搞机之旅(一)——获得root权限(刷入magisk)

    刷机不规范,抱机两行泪,谨慎刷机!! 一般获取root权限,我们都是通过软件来获取的,但是,软件破解root的成功率不是很高,现在,android版本普遍5.0+,大名鼎鼎的magisk可以直接获得r ...

  2. 设计模式之代理模式(Proxy)(2)

    代理模式是为其他对象提供一种代理以控制对这个对象的访问.在某些情况下,一个对象不适合或者不能直接引用另一个对象,而代理对象可以在客户端和目标对象之间起到中介的作用,其特征是代理类与委托类有同样的接口. ...

  3. nodejs cookie与session

    cookie.session cookie:在浏览器保存一些数据,每次请求都会带过来 *不安全.有限(4K) session:保存数据,保存在服务端 *安全.无限 ------------------ ...

  4. npm --save 、-D 、--save -dev

    npm install 和 npm i 是一样 --save 和 -S 是一样 --save-dev 和 -D 是一样的 区别: -S, --save 安装包信息将加入到dependencies(生产 ...

  5. 【代码笔记】Web-CSS-CSS Border(边框)

    一,效果图. 二,代码. <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...

  6. 企业信息化-Excel快速生成系统

    企业信息化,主要是指对企业生产运营过程所形成的信息数字化,最终形成了数字资产.大型企业为了节约成本,提高协同工作效率,都会定制ERP.办公OA.流程审批等系统做信息化支撑.但是中小企业精力投入到生成中 ...

  7. 如何把activity当成dialog

    在工作中有时候需要把activity当成dialog使用,其实做法挺简单的. 1.设置activity的style <style name="DialogTheme" par ...

  8. Android 轮播图Banner切换图片的效果

    Android XBanner使用详解 2018年03月14日 08:19:59 AND_Devil 阅读数:910   版权声明:本文为博主原创文章,未经博主允许不得转载. https://www. ...

  9. 使用Ajax轮询模拟简单的站内信箱(消息管理)功能

    前一段时间项目需要写一个类似于站内信箱的消息管理的功能,由于对前端不是很熟悉,刚开始不知道怎么做,后来看了网上的方案,现模拟一个非常简单的消息管理. 我们首先看一下最终效果的样式,就是非常简单的一个样 ...

  10. Spring MVC 数据绑定 (四)

    完整的项目案例: springmvc.zip 目录 实例 项目结构路径: 一.配置web.xml <?xml version="1.0" encoding="UTF ...