Day07 数据类型(列表,元组,字典,集合)常用操作和内置方法
数据类型
列表list:
用途:记录多个值(同种属性)
定义方式:[]用逗号分隔开多个任意类型的值
list()造出来的是列表,参数是可迭代对像,也就是可以使用for循环的对像
传入字典,出来的列表元素是字典的key
常用方法+内置的方法:
优先掌握的方法:
l = ["a","b","c","d'']
1.按索引取值,也可以更改
l[0],l[-1],l[0]="A"
通过索引赋值可以,通过索引增加值会报错,因为增加值的话肯定需要一个不存在的索引而列表中索引不存在就会报错,
2.追加
append在列表末尾增加insert(index,element) 通过索引添加元素
3.删除
del l[0] 无返回值,赋值给变量,会报错
l.remove[元素名] 根据元素值删除,返回值为None,相当于没有返回值
l.pop[index] 一个参数,根据索引删除,默认索引为-1,pop有返回值,返回的是删除的元素
区别,del和remove单纯的删除,pop可以拿到返回值
4.循环
for item in l:
print(item)
5.len
6.in not in
7.切片:索引的扩展
需要掌握的操作:
num = l.count(element) 数元素在列表中的个数,返回这个个数
extend(items)添加多个值,1个参数,可迭代对象,原理 for item in items:l.append(item)
index(object,start,stop)不存在报错
reverse()反转,无参数
sort()排序,sort(reverse = True)
sort 无返回值.
能存多个值
有序
可变
队列:先进先出,平时排队
堆栈:后进先出,上子弹
元组tuple
用途:不可变的列表
存储相同数据的列表和元组占用内存比较
列表查看,修改,会附加支持修改的机制
元组只需要查看
元组更省内存
定义方式:()小括号,用逗号分隔开多个任意类型的元素
强调:l = [1],type(l)为list
l = (1),type(l)为int
因为小扩号有包含的作用
以后元组只有一个元素时需要增加一个逗号
需要掌握的操作:
index
count
元组与列表的内存存储情况
l = ["a'',"b","c"]
列表的内存地址,放着 索引:值的内存地址的链接
元组的内存地址,放着索引和值的内存地址,元组不可变,索引对应的内存地址是不变的
字典:dict
列表是索引对应值,而字典是key对应值
其中key对value有描述性类型
定义方式:{}用逗号分开多个元素,每个元素都是key:value的形式,其中key是不可变类型,通常是字符串类型,value可以是任意类型
dict
类型转换: 1.传入的数据 x=1,y=2,z=3
2.li = [("name",egon),("age",18),("gender,male")]
3.li =["name","age","gender","height","'weight"]
dic = {}.fromkeys(li,None)
字典
优先掌握的操作:
按key取值
dic[key] = value key不存在,则新增
长度
成员运算 in not in以字典的key为准
删除
del dic[key]
dic.pop[key]返回值是key对应的是value
dic.popitem()随机删除一个键值对
循环
dic.keys()生成了,dic.values()的结果与dic.keys()一一对应
dic.items()
dic.update{dic1} 更新原字典中没有的key
res = dic.setdefault("name","Egon")
原字典存在key,不变更
原字典不存在key,增加键值对
保证字典一点存在一个key
有返回值:key存在时,没有变更,返回的是key对应的原值
key不存在时,返回新值
用法:产生一个字典{“hello“:2,“alex”:2}
s='hello alex alex say hello sb sb'
dic={}
words=s.split()
for word in words:
dic.setdefault(word,s.count(word))
print(dic)
总结:保证字典存在设置的这个key,返回值为这个key对应的值(key存在就是原值,不存在就是自己设定的值)
集合(set):可变类型
一个群体与另一个群体的关系
- 用途:关系运算
- 定义方式:{},在花括号内用逗号分隔开多个元素,元素特点是①集合内的元素必须是不可变类型②集合内元素无序③集合内元素不可重复,去重
定义一个空集合,s = set()
类型转换,set参数类型iterable可迭代
常用的操作和内置方法:
优先掌握的:
关系运算:①合集(并集) | set1|set2
②交集 & set1&set2
③差集 - set 1-set2 set2 -set1
④对称差集 ^ set1^set2
⑤==
⑥父子集:包含与被包含的关系
父集包含子集
需要掌握的
s1 = {1,2,3}
s1.update({4,5,6})
s1.pop()没有参数,随机删除1个
s1.add()加入一个元素
s1.remove()指定删除元素,元素不存在,报错无返回值
s1.discard()指定删除元素,元素不存在不会报错,无返回值
去重:
①只能针对不可变类型
②不能保证原来的顺序
name = ["egon","alex","egon","alex"]
set(name)
Day07 数据类型(列表,元组,字典,集合)常用操作和内置方法的更多相关文章
- Python列表,元组,字典,集合详细操作
菜鸟学Python第五天 数据类型常用操作及内置方法 列表(list) ======================================基本使用====================== ...
- python3笔记十八:python列表元组字典集合文件操作
一:学习内容 列表元组字典集合文件操作 二:列表元组字典集合文件操作 代码: import pickle #数据持久性模块 #封装的方法def OptionData(data,path): # ...
- python的学习笔记01_4基础数据类型列表 元组 字典 集合 其他其他(for,enumerate,range)
列表 定义:[]内以逗号分隔,按照索引,存放各种数据类型,每个位置代表一个元素 特性: 1.可存放多个值 2.可修改指定索引位置对应的值,可变 3.按照从左到右的顺序定义列表元素,下标从0开始顺序访问 ...
- **python中列表 元组 字典 集合
列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. 1.列表 列表是以方括号“[]”包围的数据集合,不同成员以“,”分隔. 列表的特 ...
- python_列表——元组——字典——集合
列表——元组——字典——集合: 列表: # 一:基本使用# 1.用途:存放多个值 # 定义方式:[]内以逗号为分隔多个元素,列表内元素无类型限制# l=['a','b','c'] #l=list([' ...
- python中列表 元组 字典 集合的区别
列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计 ...
- Day 07 数据类型的内置方法[列表,元组,字典,集合]
数据类型的内置方法 一:列表类型[list] 1.用途:多个爱好,多个名字,多个装备等等 2.定义:[]内以逗号分隔多个元素,可以是任意类型的值 3.存在一个值/多个值:多个值 4.有序or无序:有序 ...
- day6 六、元组、字典、集合的基本操作和内置方法
一.元组 1.定义 # 元组tuple # 记录多个值,当值没有改的需求是,建议用元组更好 # 定义:在()内用逗号分开任意类型的值 # name = (, , 300.5]) # print(nam ...
- Day2 列表,元组,字典,集合
一,列表 定义:[]内以逗号分隔,按照索引,存放各种数据类型,每个位置代表一个元素. list=['alex', 'jack', 'chen', 'shaoye'] #创建一个列表. 特性: 1.可存 ...
随机推荐
- Django (五) modeld进阶
day 05 models进阶 1.models基本操作 django中遵循 Code Frist 的原则,即:根据代码中定义的类来自动生成数据库表. 对于ORM框架里: 我们写的类表示数据库的表 ...
- Django REST framework 的快速入门教程
CRM-API项目搭建 序列器(Serializers) 首先,我们来定义一些序列器.我们来创建一个新的模块(module)叫做 crm/rest_searializer.py ,这是我们用来描述数据 ...
- __enter__,__exit__上下文管理协议
上下文管理协议__enter__,__exit__ 用途或者说好处: 1.使用with语句的目的就是把代码块放入with中执行,with结束后,自动完成清理工作,无须手动干预 2.在需要管理一些资源比 ...
- @Results( 中 params 怎么用
http://blog.csdn.net/z69183787/article/details/16342553 struts2的@Result annotation 如何添加params,并且在页面取 ...
- StretchDIBits速度测试(HALFTONE)
StretchDIBits速度测试(HALFTONE) 下面实验中显示窗口大小为1024*768,拉伸模式设为HALFTONE. 一.单通道图像 (1) 保持图像高度为1024,宽度从24到2024递 ...
- python入门之冒泡排序
原理: (白话描述)一列数,从左到右,依次两两比较,若左边的数大于右边的数,则两数交换,始终保持比较后左边的数小于右边的数,这样从第一个到最后一个数全部比较一次就会把这列数中的最大值排到最后(最右边) ...
- mongodb 正则
正则表达式常用来在所有语言中搜索字符串的任何模式或文字.MongoDB还提供了正则表达式功能的字符串模式使用正则表达式$regex操作符.MongoDB使用PCRE(Perl兼容正则表达式)为正则表达 ...
- 【学习笔记】六:面向对象的程序设计——理解JS中的对象属性、创建对象、JS中的继承
ES中没有类的概念,这也使其对象和其他语言中的对象有所不同,ES中定义对象为:“无序属性的集合,其属性包含基本值.对象或者函数”.现在常用的创建单个对象的方法为对象字面量形式.在常见多个对象时,使用工 ...
- 内存泄露,C++
内存泄露,C++通常是指new出来的内存没有delete掉.在你的代码里边,new了一块内存,然后马上就delete,自然就没有内存泄露了(呃……其实我也不确定啦,因为你用的是delete,而不是de ...
- 【R语言进行数据挖掘】决策树和随机森林
1.使用包party建立决策树 这一节学习使用包party里面的函数ctree()为数据集iris建立一个决策树.属性Sepal.Length(萼片长度).Sepal.Width(萼片宽度).Peta ...