python基础 Day5
python Day5
字典
其他数据类型的缺点
- 列表可以存储大量的数据,但是关联性不强。
- 列表的查询速度比较慢
其容器的数据类型为dict
其数据类型的分类
- 可变(不可哈希)的数据类型:list dict set(集合)
- 不可变(可哈希)的数据类型:str bool int tuple(不可操控原来的数据,都是建立一个新的字符串
字典的格式
字典:{}括起来,以键值对形式储存的容器数据类型
dict1={"佛祖":
{"name":"如来佛祖","sex":"男"}}
字典是以key(键)和value(值)成对组成的,但是其键必须是不可变的数据类型组成的。(int,str 比较常用 bool tuple不常用)
值可以是任意数据类型,对象
字典3.5X版本之前(包括3.5)是无序的
字典3.6X会按照初次建立字典的顺序排列,学术上不认为是有序排列的。
3.7以后都是有序排列的
字典优点:查询插入速度快,存储关联性的数据
字典的缺点:以空间换时间(字典需要占用大量的内存,内存浪费多,其实使用hash算法通过key值计算需要查找位置的)
字典的创建方式
方法一
dic=dict((("one",1),("two",2),("three",3)))
print(dic)
#结果:{'one': 1, 'two': 2, 'three': 3}
方法二
dic=dict(one=1,two=2,three=3)
print(dic)
#结果:{'one': 1, 'two': 2, 'three': 3}
方法三(官方方法)
dic=dict({"one":1,"two":2,"three":3})
print(dic)
#结果:{'one': 1, 'two': 2, 'three': 3}
字典的增删改查
增
方法一
#如果初始的字典没有需要加入的key,则是真假,如果已经含有了key,重新赋值就是修改
dic={"name":"如来佛祖","sex":"man"}
dic['age']="无限"
print(dic)
#结果 {'name': '如来佛祖', 'sex': 'name', 'age': '限'}
方法二
dic={"name":"如来佛祖","sex":"man"}
dic.setdefault("hobby","洗脑")
print(dic)
#结果 {'name': '如来佛祖', 'sex': 'name', 'hobby': '洗脑'}
删 pop
方法一 pop 同样能返回删除参数
dic={"name":"如来佛祖","sex":"man"}
ret=dic.pop("sex","没有此键")#设置第二个参数则无论字典中有无此键都不会报错
print(dic)
#结果 {'name': '如来佛祖'}
方法二 clear 清空
dic={"name":"如来佛祖","sex":"man"}
ret=dic.clear()
print(dic)
#结果 {}
方法三 del 没有pop好用,遇到字典中没有此键就会报错
dic={"name":"如来佛祖","sex":"man "}
del dic["sex"]
print(dic)
#结果 {'name': '如来佛祖'}
改 在增加的地方已经说过
查
方法一 通过key的提示将value值查找出来
dic={"name":"如来佛祖","sex":"name","hobby_list":["假仁假义","大骗子","印度邪教"]}
print(dic["hobby_list"])
#结果 ['假仁假义', '大骗子', '印度邪教']
方法二 get
#get这个方法的获取更优势,理由同pop一样
dic={"name":"如来佛祖","sex":"name","hobby_list":["假仁假义","大骗子","印度邪教"]}
ls=dic.get("hobby_list")#同pop设置第二参数则字典有无此键都不会报错
print(ls)
#结果 ['假仁假义', '大骗子', '印度邪教']
方法三 keys()
#查出所有keys值
#这个数字类型可以转化为列表
dic={"name":"如来佛祖","sex":"name","hobby_list":["假仁假义","大骗子","印度邪教"]}
print(dic.keys())
#dict_keys(['name', 'sex', 'hobby_list'])
#将其转化为列表
dic={"name":"如来佛祖","sex":"name","hobby_list":["假仁假义","大骗子","印度邪教"]}
print(list(dic.keys()))
#结果 ['name', 'sex', 'hobby_list']
方法四 items
#将字典的keys和values值分别取出来,这里功能用到了元组的拆包
dic={"name":"如来佛祖","sex":"name","hobby_list":["假仁假义","大骗子","印度邪教"]}
for key,values in dic.items():
print(key,values)
#结果 name 如来佛祖
# sex name
# hobby_list ['假仁假义', '大骗子', '印度邪教']
练习
1.如content=input("输入内容:")用户输入 5+9+6 +12 +13然后进行计算
content=input("请输入需要的内容:")
list=content.split("+")
result=0
for i in list:
result+=int(i)
print(result)
2.计算用户输入的内容中有几个整数(以个位数为单位)如:content=input("请输入内容:")如sfhlsdfh3445fdlsfh+=455f
content=input("请输入需要的内容:")
number=0
for i in content:
if i.isdecimal():
number+=1
print(number)
3.判断一句话是否为回文。回文:正反念和反正念是一样的。列如,上海自来水来自海上
content1=content[::-1]
if content==content1:
print("这是回文")
else:
print("这不是回文")
4.找出li列表中的元素,移除每个(for)元素的空格,并找出一“A"或者”a"开头,并以"C"结尾的所有元素,并添加到一个新的列表中,最后循环打印这个列表。
li=["TaiBai ","alexC","AbC ","egon","riTiAn","WuSir","aqc"]
newli=[]
for i in li:
i1=i.strip()
# if i1.startswith("A") or i1.startswith("a") and i1.endswith("C"):
if i1.upper().startswith("A") and i1.endswith("C"):
newli.append(i1)
for j in newli:
print(j)
5.如下列表
li=[1,3,4,"xiaoming",[3,7,8,"taiwan"],5]
循环打印列表中的每个元素,遇到列表则再循环打印出它里面元素
li=[1,3,4,"xiaoming",[3,7,8,"taiwan"],5]
for i in li:
if type(i)==list:
for j in i:
print(j)
else:
print(i)
python基础 Day5的更多相关文章
- Python基础Day5
一.字典 ①字典是python的基础数据类型之一 ②字典可以存储大量的数据,关系型数据 ③字典也是python中唯一的映射类的数据类型 字典是以键值对的形式存在的,{键:值} 字典的键必须是不可变的数 ...
- 第五章:Python基础の生成器、迭代器、序列化和虚拟环境的应用
本课主题 生成器介紹和操作实战 迭代器介紹和操作实战 序例化和反序例化 Json 和 Pickle 操作实战 字符串格式化的应用 创建虚拟环境实战 本周作业 生成器介紹和操作实战 什么是生成器,生成器 ...
- Python基础学习总结(持续更新)
https://www.cnblogs.com/jin-xin/articles/7459977.html 嗯,学完一天,白天上班,眼睛要瞎了= = DAY1 1,计算机基础. CPU:相当于人的大脑 ...
- python基础-基础知识(包括:函数递归等知识)
老男孩 Python 基础知识练习(三) 1.列举布尔值为 False 的值空,None,0, False, ", [], {}, () 2.写函数:根据范围获取其中 3 和 7 整除的所有 ...
- Python基础 小白[7天]入门笔记
笔记来源 Day-1 基础知识(注释.输入.输出.循环.数据类型.随机数) #-*- codeing = utf-8 -*- #@Time : 2020/7/11 11:38 #@Author : H ...
- python之最强王者(2)——python基础语法
背景介绍:由于本人一直做java开发,也是从txt开始写hello,world,使用javac命令编译,一直到使用myeclipse,其中的道理和辛酸都懂(请容许我擦干眼角的泪水),所以对于pytho ...
- Python开发【第二篇】:Python基础知识
Python基础知识 一.初识基本数据类型 类型: int(整型) 在32位机器上,整数的位数为32位,取值范围为-2**31-2**31-1,即-2147483648-2147483647 在64位 ...
- Python小白的发展之路之Python基础(一)
Python基础部分1: 1.Python简介 2.Python 2 or 3,两者的主要区别 3.Python解释器 4.安装Python 5.第一个Python程序 Hello World 6.P ...
- Python之路3【第一篇】Python基础
本节内容 Python简介 Python安装 第一个Python程序 编程语言的分类 Python简介 1.Python的由来 python的创始人为吉多·范罗苏姆(Guido van Rossum) ...
随机推荐
- 题解 UVA1608 【不无聊的序列 Non-boring sequences】
思路: 算法很显然: 一.在区间\([l,r]\)找到一个只出现一次的元素P(如果不存在,那么序列\(boring\)) 二.递归处理区间\([l,p-1]\)和区间\([p+1,r]\). 其关键在 ...
- 感性认识JWT
常见的认证机制 今天我么聊一聊JWT. 关于JWT,相信很多人都已经看过用过,他是基于json数据结构的认证规范,简单的说就是验证用户登没登陆的玩意.这时候你可能回想,哎哟,不是又那个session么 ...
- js原声代码 轮播图
js轮播图 html部分:建立div,内嵌img标签,可以设置大小, <!doctype html> <html> <head> <meta charset= ...
- SpringSecurity匹配规则介绍
SpringSecurity匹配规则一 URL匹配 requestMatchers() 配置一个request Mather数组,参数为RequestMatcher 对象,其match 规则自定义,需 ...
- Vue数据产生变化需要页面渲染完之后执行某操作
1.数据产生变化或者页面需要vue数据渲染完之后加载的东西 Vue.nextTick(function () { alert(123); }); 2 调用vue方法 --------------Vue ...
- pandas_学习的时候总会忘了的知识点
对Series 对象使用匿名函数 使用 pipe 函数对 Series 对象使用 匿名函数 pd.Series(range(5)).pipe(lambda x,y,z :(x**y)%z,2,5) p ...
- 2-Numpy之hstack、vstack、concatenate区别
concatenate与hstack.vstack的异同点: 都表示拼接数组,concatenate可以实现hstack和vstack的功能,只需要通过调整参数axis的值即可. 其中:v表示垂直(V ...
- ORACLE不完成恢复ORA-00392,ORA-00312,ORA-00349
背景: 进行测试库不完全恢复,log_file_name_convert没调整好.rac-asm至单实例-文件系统,recover完成后,mount状态的database 执行 alter data ...
- Qt 乱码
个人认识: 乱码的原因: 在编写代码时-->文件的格式--->编译器对文件进行编译的时候看到的只是二进制(乱码就出现在这里) 应合适方法 通知编译器(为什么说通知编译器呢?因为个人觉得这样 ...
- 数据分析学习 third week (7.29~8.4)
概率分布简介 简单地介绍下常用概率分布的理论知识. 基础概念 1.概率 概率直观上是指一个事件发生可能性大小的数量指标 概率的统计定义:在不变的条件下,重复进行$n$次试验,事件$A$发生的频率稳定在 ...