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. spring boot 页面根路径获取和jsp获取的不同之处(粘贴即用)

    不同之处已做高亮. jsp 写法: <script type="text/javascript" src="${pageContext.request.contex ...

  2. MATLAB 中 ksvdbox和ompbox 工具箱的安装和使用

    下载工具箱 链接: http://www.cs.technion.ac.il/~ronrubin/software.html 下载好工具箱之后, 要将解压后的文件夹添加到MATLAB的安装目录下的to ...

  3. SAP MM ME1M报表结果不科学?

    SAP MM ME1M报表结果不科学? 做过SAP MM顾问的都知道,报表ME1M可以查询物料的info record列表,即是说可以以列表的形式批量显示多个物料的采购价格主数据. 但是这个报表有个不 ...

  4. linux初学者常用必备命令整理

    Linux命令学习 1.文件&目录处理 ls -a 全部文件 -l 详细信息 -r 递归显示子目录结构 ls -al 相当于 ls -a -l cd ..上级目录 .当前目录 ~家目录 cd ...

  5. 《Flask Web开发》学习笔记

    第一部分 Flask简介 前言:想熟练掌握一门web框架,为以后即将诞生的测试工具集做准备.为什么选择flask要做熟练掌握的一门框架,而不是其他的,最主要的原因是可以随意定制. 特别提醒:这本书的代 ...

  6. Netty学习笔记(一) 实现DISCARD服务

    官方那个给出的介绍是:Netty是由JBOSS提供的一个java开源框架.Netty提供异步的.事件驱动的网络应用程序框架和工具,用以快速开发高性能.高可靠性的网络服务器和客户端程序.然后我们简单理解 ...

  7. 测者的性能测试手册:JVM的监控利器

    测者的性能测试手册:JVM的监控利器 每次聊起性能测试,最后的终结话题就是怎么做优化.其实在Java的复杂项目中都会有内存不足问题.内存泄露问题.线程死锁问题.CPU问题.这些问题工程测试或者是小压力 ...

  8. 【原】Java学习笔记002 - JAVA SE编码规范

    /* * 编码规范: * 1.所有的命名遵循"见名知意"的原则 * 2.所有的命名不允许使用汉字或拼音 * 3.Java的工程命名建议使用小写,比如:oa.crm.cms... * ...

  9. 歌曲的BPM (Beat Per Minute)--每分钟节拍数

    因为老爸喜欢跳舞,总让我帮他整理舞曲,一会儿要慢三,一会儿要慢四,一会儿又要快四....我真的分不清啊 我想啊,慢三,慢四这些应该是歌曲的节拍吧(后来得知专业术语叫BPM),于是就在网上搜看看能不能通 ...

  10. Chinese word segment based on character representation learning 论文笔记

    论文名和编号 摘要/引言 相关背景和工作 论文方法/模型 实验(数据集)及 分析(一些具体数据) 未来工作/不足 是否有源码 问题 原因 解决思路 优势 基于表示学习的中文分词 编号:1001-908 ...