Python基础学习三 字典、元组
一、元组
元组,提示别人,这个值是不能被改变的,元组的定义方式是用(),小括号;
元组只有两个方法,那就是count和index
mysql1 = ('127.0.0.1',3306,'my','root',123456)
mysql2 = ('127.0.0.1',3307,'my','root','root')
print(mysql1.count('my'))#找个数
print(mysql1.index('my'))#返回下标
输出:1 2
print(mysql2.count('root'))#找个数
print(mysql2.index('root'))#返回下标,且为第一个返回值
输出:2 3
#元组也是list,只不过是不可变的
二、字典
特性:
字典是无序的,因为它没有下标,用key来当索引,所以是无序的
字典的key必须是唯一的,因为它是通过key来进行索引的,所以key不能重复,天生就去重
1、查看
d = { 'name':'test001',
'age':18,
'sex':'男',
'addr':'昌平区',
'money':10000000 ,
}
print(d['name'])#如果写了不存在的key,会报错
print(d.get('SDFSDF'))#如果get不到的话,返回None
输出: test001
None
2、增加
d = { 'name':'test001',
'age':18,
'sex':'男',
'addr':'昌平区',
'money':10000000 ,
}
d['height']=198
d.setdefault('weight',130)#字典是无序的
d = {'marry':[18,'北京'],'amy':[20,'山东'],'lily':[25,'河南']}
d['andy']=[22,'河北']#增加
print(d.keys())#获取到字典所有的key
print(d.values())#获取到所有的values
输出:dict_keys(['marry', 'amy', 'lily', 'andy'])
dict_values([[18, '北京'], [20, '山东'], [25, '河南'], [22, '河北']])
3、修改
d = { 'name':'test001',
'age':18,
'sex':'男',
'addr':'昌平区',
'money':10000000 ,
'height':198
}
d['shengao']=200 #如果这个key存在的话,修改他的值,如果key不存在的话,新增一个
print(d.keys())#获取到字典所有的key
print(d.values())#获取到所有的values
4、删除
d = { 'name':'test001',
'age':18,
'sex':'男',
'addr':'昌平区',
'money':10000000 ,
'height':198
}
d.pop('height')#删除某个key
del d['addr']#删除某个key
d.popitem()#随机删除一个(一般删除末尾对)
d.clear()#清空字典
print(d.keys())#获取到字典所有的key
print(d.values())#获取到所有的values
注意:
# res = list(d.items())
# print(res[0])
# for k in d: #性能更好
# print(k,d.get(k))
5、嵌套
stus = {
'user1': {
'age': 18,
'sex': '男',
'addr': '昌平区',
'money': 10000000,
'jinku': {
'建行卡': 80000,
'工商卡': 800000,
'招商卡': 8000000
}
},
'user3': {
'age': 19,
'sex': '女',
'addr': '昌平区',
'money': 10000000,
"bag": {
'lv': 20,
'prada':10
}
},
}
方法一:
a = stus['user3']['bag'].values()
print(a)
print(sum(a))
方法二:
all_money = stus['user1']['jinku'].values()
sum_money = 0
for money in all_money:
sum_money= sum_money+money
print(sum_money)
总结:可变变量 :list、字典;不可变变量:元组、字符串
Python基础学习三 字典、元组的更多相关文章
- Python基础学习三
Python基础学习三 1.列表与元组 len()函数:可以获取列表的元素个数. append()函数:用于在列表的最后添加元素. sort()函数:用于排序元素 insert()函数:用于在指定位置 ...
- Python基础学习 -- 列表与元组
本节学习目的: 掌握数据结构中的列表和元组 应用场景: 编程 = 算法 + 数据结构 数据结构: 通过某种方式(例如对元素进行编号)组织在一起的数据元素的集合,这些元素可以是数字或者字符,或者其他数据 ...
- Python基础学习Day5 字典的增、删、改、查的用法 分别赋值
一.字典的介绍 字典:字典是Python的基础数据类型之一:字典可以存储大量数据,关系型数据. 同样是Python中唯一的映射类数据类型. 数据类型的分类: 可变的数据类 ...
- Python 基础学习之字典
1.基础代码 ##第六章 字典学习 test={'} print(test['a']) print(test['b']) 返回结果为: black123 2.基础知识: Python中的字典是一系列键 ...
- python基础学习笔记——字典
字典(Dictionary) 字典是另一种可变容器模型,且可存储任意类型对象. 字典的每个键值 key=>value 对用冒号 : 分割,每个键值对之间用逗号 , 分割,整个字典包括在花括号 { ...
- python 基础学习4 字典和循环语句
学了这么多天的基础,好着急的想什么时候可以开始写个小程序,今天还是静下心来把字典和循环语句学习了 关于字典,主要是了解了字典的创建,和映射,以及一些基本的运算法,运算法不一一列出,运算法在用到的时候会 ...
- 【Python基础学习三】数字(Number)
Python Number 数据类型用于存储数值. 数据类型是不允许改变的,这就意味着如果改变 Number 数据类型的值,将重新分配内存空间. Python 四种数值类型: 整型(Int) - 通常 ...
- python基础知识三 字典-dict + 菜中菜
3.7字典:dict+菜中菜 1.简介 无序,可修改,用于存储数据,大量,比列表快,将数据和数据之间关联 定义:dict1 = {'cx':10,'liwenhu':80,'zhangyu': ...
- python 基础学习(字典对象,set对象)
1.dict 字典对象 a.定义对象 d={'a':14,'b':12}b.通过key获取value d['a'] 方法1.判断key是否存在 if 'a' in d: d['a']方法2:通过用ge ...
随机推荐
- HDU 1410 PK武林盟主
Problem Description 枫之羽认为自己很强,想当武林盟主,于是找现任武林盟主氢氧化铜挑战.氢氧化铜欣然接受了挑战,两人约好于下个月的月圆之夜在HDU校园内的三根柱子上进行决战.这场PK ...
- 内存保护机制及绕过方案——利用未启用SafeSEH模块绕过SafeSEH
前言:之前关于safeSEH保护机制的原理等信息,可在之前的博文(内存保护机制及绕过方案中查看). 利用未启用SafeSEH模块绕过SafeSEH ⑴. 原理分析: 一个不是仅包含中间语言(1L)且 ...
- java.util.concurrent.ExecutionException: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[localhost].StandardContext[/xiaozao_web]]
二月 20, 2017 11:30:28 上午 org.apache.tomcat.util.digester.SetPropertiesRule begin警告: [SetPropertiesRul ...
- LeetCode OJ:Happy Number(欢乐数)
Write an algorithm to determine if a number is "happy". A happy number is a number defined ...
- Four-operations: 使用node.js实现四则运算程序
一. 项目基本信息 项目成员: 陈旭钦, 郭鹏燕 项目仓库: https://github.com/Yanzery/Four-operations 二. PSP2.1表格 PSP2.1 Persona ...
- 【tensorflow:Google】四、深层神经网络
一.深度学习与深层神经网络 1.线性模型局限性 线性模型无论多少层,表达能力是一致的.可以通过激活函数实现非线性. 2.多层网络可以解决异或运算 二.损失函数定义 1.经典损失函数: 分类问题: 二分 ...
- Arcgis for Js之Graphiclayer扩展详解
在前两节,讲到了两种不同方式的聚类,一种是基于距离的,一种是基于区域范围的,两种不同的聚类都是通过扩展esri/layers/GraphicsLayer方法来实现的.在本节,就详细的讲讲esri/la ...
- CRC-16校验原理
最详细易懂的CRC-16校验原理(附源程序) 1.循环校验码(CRC码): 是数据通信领域中最常用的一种差错校验码,其特征是信息字段和校验字段的长度可以任意选定. 2.生成CRC码的基本原理: 任意一 ...
- 基于tcp协议的粘包问题(subprocess、struct)
要点: 报头 固定长度bytes类型 1.粘包现象 粘包就是在获取数据时,出现数据的内容不是本应该接收的数据,如:对方第一次发送hello,第二次发送world,我放接收时,应该收两次,一次是hel ...
- [HAL]5.中断里调用HAL_Delay()进入死循环的原因
中断里调用HAL_Delay()进入死循环的原因 摘自:http://blog.csdn.net/alwxkxk/article/details/47204677 CUBE生成的程序中, SysTi ...