Python 全栈开发:dict(字典)常用方法操作、dict嵌套
数据类型的划分:可变数据类型和不可变数据类型。
不可变数据类型(可哈希):元祖、bool、int、str
可变数据类型(不可哈希):list、dict,set(集合)
dict(字典):
dict(字典):映射数据类型
dict = {"key":value}
dict key 必须不可变数据类型,可哈希。
value 任意数据类型
dict 优点:二分法查找去查询
存储大量的关系型数据
特点:无序的(3.5及其之前的版本)
# dict = {
# 'name':['韩非','黄有华','林颖','谢龙','李霞霞','纪伟鹏'],
# '配送':[{'num':12,'avera_age':20}],
# True:1,
# (1,2,3):'wuyiyi',
# 2:'二哥',
# }
# print(dict)
#例子
# dict1 = {'age':18,'name':'jone','sex':'male'} #增 dict['key']:value 或 setdefault(key,value)
# dict1['hight']=185 #没有键值对,添加
# dict1['age'] = 16 #如果有键值对,则值覆盖
# print("dict1['hight']=185 and dict1['age']=16",dict1)
# 输出结果:
# dict1['hight']=185 and dict1['age']=16 {'hight': 185, 'sex': 'male', 'age': 16, 'name': 'jone'}
#setdefault() 已经存在键值对,不做任何改变,没有在添加
# dict1.setdefault('weight',150)
# dict1.setdefault('name','alex')
# print(dict1)
# 输出结果:
# dict1['hight']=185 and dict1['age']=16 {'hight': 185, 'sex': 'male', 'age': 16, 'name': 'jone'} #删 pop(key,'设置返回值')、popitem(key)随机删除,有返回值、del dict[key] 不存在会报错、clear()清空字典
#ps:None是一种数据类型
# print(dict1.pop('age'),dict1)
# print(dict1.pop('yijiajun',None),dict1)
# 输出结果:
# 18 {'name': 'jone', 'sex': 'male'}
# None {'name': 'jone', 'sex': 'male'}
# print(dict1.popitem(),dict1)
# 输出结果:
# ('name', 'jone') {'sex': 'male', 'age': 18}
# del dict1['age']
# print(dict1)
# 输出结果:
# {'name': 'jone', 'sex': 'male'}
# del dict1
# print(dict1)
# 输出结果:
# print(dict1)
# NameError: name 'dict1' is not defined #改
# dict1['age'] = 20
# print(dict1)
# 输出结果:
# {'name': 'jone', 'sex': 'male', 'age': 20}
#update() 已经存在的键值对,会更新value,不存在的键值对,则添加
# dict2 = {'name':'yijiajun','heigh':175,'weight':75}
# dict1.update(dict2)
# print(dict1,dict2) #查
# print(dict1.keys(),type(dict1.keys()))
# print(dict1.values(),type(dict1.values()))
# print(dict1.items(),type(dict1.items()))
# print(dict1.get('name'),type(dict1.get('name')))
# print(dict1.get('yijia'),'不存在key')
# 输出结果:
# dict_values([18, 'male', 'jone']) <class 'dict_values'>
# dict_items([('age', 18), ('sex', 'male'), ('name', 'jone')]) <class 'dict_items'>
# jone <class 'str'>
# None 不存在key #for .....in.....遍历任何项目的序列
#遍历key
#方法一
# for i in dict1.keys():
# print(i)
#方法二
# for i in dict1:
# print(i)
#遍历value
# for i in dict1.values():
# print(i)
#以元祖的形式同时遍历key和value
# for i in dict1.items():
# print(i,type(i))
# 输出结果:
# ('sex', 'male') < class 'tuple'>
# ('name', 'jone') <class 'tuple'>
# ('age', 18) < class 'tuple'>
#以字符串的形式同时遍历key和value
# for k,v in dict1.items():
# print(k,v,type(k),type(v))
# 输出结果:
# dict_values([18, 'male', 'jone']) <class 'dict_values'>
# dict_items([('age', 18), ('sex', 'male'), ('name', 'jone')]) <class 'dict_items'>
# jone <class 'str'>
# None 不存在key #字典嵌套
# dic = {
# 'name':['yijiajun','yijiaping','yijiaxing'],
# 'home.yee':{
# 'born' :1995,
# 'count':85,
# 'old':'grandfather'
# },
# True:1,
# (1,2,3):'yimeiling',
# 'age':21
#
# }
# dic['age'] = 56
# dic['name'][0] = dic['name'][0].upper()
# dic['name'].append('wangxizhi')
# dic['home.yee']['color'] = 'red'
# dic['home.yee'].setdefault('like','fish')
# dic['home.yee'].pop('born','已经删除')
# print(dic['home.yee'].pop('born','已经删除')) #课间题 统计数字出现的次数(连续的数字为1个)
info = input('请输入您要检测的数字:').strip()
for i in info:
if i.isalpha():
info = info.replace(i,' ')
l = info.split( )
print(l)
print(len(l))
Python 全栈开发:dict(字典)常用方法操作、dict嵌套的更多相关文章
- python 全栈开发,Day101(redis操作,购物车,DRF解析器)
昨日内容回顾 1. django请求生命周期? - 当用户在浏览器中输入url时,浏览器会生成请求头和请求体发给服务端 请求头和请求体中会包含浏览器的动作(action),这个动作通常为get或者po ...
- python 全栈开发,Day8(文件操作)
一.文件操作流程 文件以什么编码存储的,就以什么编码打开 参数: 1.文件路径 2.编码方式,encode 3.执行动作(打开方式):只读,只写,追加,读写,写读... 打开一个已经存在的文件 f = ...
- python全栈开发-Day9 函数对象、函数嵌套、名称空间与作用域
一 .函数对象 一 .函数是第一类对象,即函数可以当作数据传递 可以被引用 可以当作参数传递 返回值可以是函数 可以当作容器类型的元素 二. 利用该特性,优雅的取代多分支的if def foo(): ...
- python全栈开发中级班全程笔记(第二模块、第四章)(常用模块导入)
python全栈开发笔记第二模块 第四章 :常用模块(第二部分) 一.os 模块的 详解 1.os.getcwd() :得到当前工作目录,即当前python解释器所在目录路径 impor ...
- Python全栈开发【模块】
Python全栈开发[模块] 本节内容: 模块介绍 time random os sys json & picle shelve XML hashlib ConfigParser loggin ...
- Python全栈开发【基础三】
Python全栈开发[基础三] 本节内容: 函数(全局与局部变量) 递归 内置函数 函数 一.定义和使用 函数最重要的是减少代码的重用性和增强代码可读性 def 函数名(参数): ... 函数体 . ...
- Python全栈开发【基础二】
Python全栈开发[基础二] 本节内容: Python 运算符(算术运算.比较运算.赋值运算.逻辑运算.成员运算) 基本数据类型(数字.布尔值.字符串.列表.元组.字典) 其他(编码,range,f ...
- python 全栈开发,Day99(作业讲解,DRF版本,DRF分页,DRF序列化进阶)
昨日内容回顾 1. 为什么要做前后端分离? - 前后端交给不同的人来编写,职责划分明确. - API (IOS,安卓,PC,微信小程序...) - vue.js等框架编写前端时,会比之前写jQuery ...
- Python全栈开发【面向对象进阶】
Python全栈开发[面向对象进阶] 本节内容: isinstance(obj,cls)和issubclass(sub,super) 反射 __setattr__,__delattr__,__geta ...
- Python全栈开发【面向对象】
Python全栈开发[面向对象] 本节内容: 三大编程范式 面向对象设计与面向对象编程 类和对象 静态属性.类方法.静态方法 类组合 继承 多态 封装 三大编程范式 三大编程范式: 1.面向过程编程 ...
随机推荐
- error:while loading shared libraries: libevent-2.1.so.6: cannot open shared object file: No such file or directory
执行 memcached 启动命令时,报错,提示:error while loading shared libraries: libevent-2.1.so.6: cannot open shared ...
- io.fabric8.kubernetes对pv和pvc的增删查改
1.新建maven项目k8stest,pom.xml如下: <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns: ...
- UVa 11419 SAM I AM (最小覆盖数)
题意:给定一个 n * m 的矩阵,有一些格子有目标,每次可以消灭一行或者一列,问你最少要几次才能完成. 析:把 行看成 X,把列看成是 Y,每个目标都连一条线,那么就是一个二分图的最小覆盖数,这个答 ...
- WCF Service 配置文件注释(转)
<?xml version="1.0" encoding="utf-8" ?> <configuration> <system.S ...
- awk基础01-基本用法
什么是awk awk 是一门解释型的编程语言,支持条件判断,数组.循环等功能.可用于文本处理.输出格式化的文本信息.执行数学运算.字符串等操作. awk在处理文件时按行进行逐行处理,即 ...
- delphi 10.1 berlin datasnap提交clientdataset.delta报:invalid variant type conversion(类型转换错误)问题的解决
delphi 10.1 berlin datasnap提交clientdataset.delta报:invalid variant type conversion(类型转换错误)问题的解决,需要打这个 ...
- Postgres 主从配置(五)
PostgreSQL 9.4 新增的一个特性, replication slot, 1. 可以被流复制的sender节点用于自动识别它xlog中的数据在下面的standby中是否还需要(例如, st ...
- [C#] ??雙問號的意思及用法
int? x = null; int y = x ?? -1; 上面二行中,第一行是將x變數放入null,為什麼int能放null,可以參考另一篇文章http://charleslin74.pixne ...
- 疑难杂症--SQL SERVER 18056的错误
朋友遇到一个很棘手的问题,查看服务器日志,报以下错误: ::,spid296,未知,错误: ,严重性: ,状态: . ::,spid495,未知, The client was unable < ...
- 在 Docker 上运行一个 RESTful 风格的微服务
tags: Microservice Restful Docker Author: Andy Ai Weibo:NinetyH GitHub: https://github.com/aiyanbo/d ...