#什么是元祖:元祖是一个不可变的列表(没有改的需求)

#======================================基本使用======================================
#1、用途:用于存放多个值,当存放的多个值只有读的需求 没有改的需求时用元祖最合适

#2、定义方式:在()内用,分割开多个任意类型的值
t=(1,3.1,'aaa',(1,2,3),['a','b'])
t=tuple(...)
res=tuple('hello')
res=tuple(['x':1,'y':2])
print(res)

#3、常用操作+内置的方法
#优先掌握的操作:
#1、按索引取值(正向取+反向取):只能取
t=('a','b',1)
t[0]=111

#2、切片(顾头不顾尾,步长)
t=('h','e','l','l','o')
res=[1:3] el
print(res)
print(t) 不可变 切边不会改变原值
#3、长度
t=('h','e','l','l','o')
print(len(t))
#4、成员运算in和not in
t=('h','e','l','l','o')
print('h' in t) True

#5、循环
t=('h','e','l','l','o')
for item in t:
print(item)

#======================================该类型总结====================================
#存多个值

#有序

#不可变(1、可变:值变,id不变。可变==不可hash 2、不可变:值变,id就变。不可变==可hash)
元组的元素不可变 列表可变 指的是内存地址可以变
t=(1,'a',['x','y','z'])
print(id(t))
t[2][0]='X'
print(t)
print(id(t))

#掌握方法
t=('a','b','a')
print(t.index('a')) 下标是0
t.index('xxx')
print(t.count(a)) 一共两个

字典类型
#======================================基本使用======================================
#1、用途:用来存放多个(不同种类的)值

#2、定义方式:在{}内用逗号分开多个key:value的元素,其中value可以是热议数据类型,而key的功能通常是用来描述value的所以key通常是字符串类型,但其实key必须是不可变类型(int\float\str\tuple)
d={0:'x',1.3:'y','k1':'z',(1,2,3):'aaa'}
print(d[(1,2,3)])#输出字典中key为(1,2,3)的value
d=dict(...)
print(d[(1,2,3)])
d1={[1,2,3]:'aaa'}不可以这样定义

d=dict([('k1',1),('k2',2),('k3',3)]) #将这种数据类型转换成字典
print(d) 输出整个字典

d=dict((('k1',1),('k2',2),('k3',3)))
print(d) 换成元祖也可以 第一个值相当于key第二个值相当于value

l=[('k1',1),('k2',2),('k3',3)]
d={}
for t in l:
print(t) #取出三个小元祖
d[t[0]]

l=[('k1',1),('k2',2),('k3',3)]
d={}
for t in l:
k,v=t
d[k]=v
print(d)
d=dict(l)
print(d)

d=dict(x=1,y=2,z=3)
print(d)

#3、常用操作+内置的方法
#优先掌握的操作:
#1、按key存取值:可存可取
d={'x':1}
print(d['x']) #1
print(id(d))
d['x']=1111
print(d)
print(id(d))
key存在的情况下 id不变 说明字典是可变类型

key不存在情况下
d['y']=2222
print(d)
也可以在里面加值
l=['a','b']
l[2]='c'#报错 不能做赋值操作

索引不存在 列表不能往里面加值
字典可以在不存在的key里面加值

#2、长度len
d={'x':1,'y':2,'z':3}
print(len(d))
长度是3
#3、成员运算in和not in
d={'x':1,'y':2,'z':3}
print(1 in d) false
print('x' in d) true
字典的成员运算按照key来的

#4、删除
d={'x':1,'y':2,'z':3}
del d['y']
print(d)

d={'x':1,'y':2,'z':3}
res=d.pop('y') #返回y对应的那个值
print(res) #res为2
print(d) #y被删除

res=d.popitem()
print(res) #返回删除的那个key:value
print(d) #输出删除后d的值

字典是无序的popitem是随机删除
#5、键keys(),值values(),键值对items()
d={'x':1,'y':2,'z':3}
d.keys()输出key
print(list(d.keys()))
d.values()输出value
print(list(d.values()))
d.item()输出字典
print(list(d.items()))

#6、循环

for k in d.keys():
print(k)

for k in d:
print(k)#默认循环是直接输出key

print(list(d.keys()))
for v in d.values():
print(v)
print(list(d.values()))
for k,v in d.items():
print(k,v)
print(list(d.items()))

#======================================该类型总结====================================
#存一个值or存多个值

#有序or无序

#可变or不可变(1、可变:值变,id不变。可变==不可hash 2、不可变:值变,id就变。不可变==可hash)

#需要掌握的操作
d={'name':'egon','age':18,'sex':'male','hobblies':[1,2,3]}
v=d.get('namexxxx')#不存在key返回值为None不会报错
print(v)

v1=d.get('name')#返回值为value
print(v1)

update放法
d={'name':'egon','age':18,'sex':'male','hobblies':[1,2,3]}
d.update({'x':1,'name':"EGON"})
print(d) #更新d 没有key的添加 有key的修改(更新)

#fromkeys:需求是快速新造出一个字典,value的初始值全都为None,而key是来自于一个列表
keys=['name','age','sex']
d={}.fromkeys(keys,None) #keys是d中的key value都为None
print(d)
相当于下面代码:
keys=['name','age','sex']
d={}
for k in keys:
d[k]=None
print(d)

#setdefault

按照默认的操作形式
d={"x":1,"y":3}
d['x']=1111
d['z']=12345
存在就改值 不存在就加值

按照setdefault的形势
d={"x":1,"y":3}
res=d.setdefault('x':11111)#在key存在的情况下不修改值 会返回原值
print(d)
print(res)

res=d.setdefault('z',11111)#在key不存在的情况下增加一个新的值 会返回新增的值
print(d)
print(res)

#练习
s='hello alex alex say hello sb sb'
#d={'hello':2,'alex':2,'say':1,'sb':2}

d={}
words=s.split()
print(words)
for word in words:
#d[word]=words.count(word)#d['hello']=word.count('hello')#每次重复添加 优化操作 如下代码
d.setdefault(word,words.count(word))

print(d)
#['hello', 'alex', 'alex', 'say', 'hello', 'sb', 'sb']
#{'hello': 2, 'alex': 2, 'say': 1, 'sb': 2}

for word in words:
d[word]=words.count(word)
print(d)

print(words)
d['hello']=words.count('hello')
d['alex']=words.count('alex')
print(d)

补充元祖符号
t=(1,)
print(t,type(t))
对于元祖 只有一个元素后面必须加上逗号 不加逗号这个()就是包含的意思

name=input('>>:').strip()
res='my name is %s' %name
print(res.center(50,'*'))

两步并做一步
()的一个用法 他有这包含的 意思
name=input('>>:').strip()
print(('my name is %s' %name).center(50,'*'))

元祖&字典的更多相关文章

  1. python学习第八讲,python中的数据类型,列表,元祖,字典,之字典使用与介绍

    目录 python学习第八讲,python中的数据类型,列表,元祖,字典,之字典使用与介绍.md 一丶字典 1.字典的定义 2.字典的使用. 3.字典的常用方法. python学习第八讲,python ...

  2. python学习第七讲,python中的数据类型,列表,元祖,字典,之元祖使用与介绍

    目录 python学习第七讲,python中的数据类型,列表,元祖,字典,之元祖使用与介绍 一丶元祖 1.元祖简介 2.元祖变量的定义 3.元祖变量的常用操作. 4.元祖的遍历 5.元祖的应用场景 p ...

  3. python学习第六讲,python中的数据类型,列表,元祖,字典,之列表使用与介绍

    目录 python学习第六讲,python中的数据类型,列表,元祖,字典,之列表使用与介绍. 二丶列表,其它语言称为数组 1.列表的定义,以及语法 2.列表的使用,以及常用方法. 3.列表的常用操作 ...

  4. python-列表元祖字典集合

    列表 list = ["a", "b", "c", "d"]元祖 tup = (1, 2, 3, 4, 5 ) 1.元组 ...

  5. python基础学习笔记第四天 list 元祖 字典

    一 LIST方法 列表操作包含以下函数:1.cmp(list1, list2):比较两个列表的元素 2.len(list):列表元素个数 3.max(list):返回列表元素最大值 4.min(lis ...

  6. python 元祖字典集合

    一.元祖 1.用途:记录多个值,当多个值没有改变的需求,元祖不能修改,但元祖里的数据的数据可以修改. 2.定义方式:在()内用逗号分隔开多个任意值. 思考:如果定义一个只有一个一个值的元祖. # t ...

  7. 06 元祖 字典 集合set

    元组 定义: ti=() print(ti,type(ti)) 参数:for可以循环的对象(可迭代对象) t2=tuple(") # ('1', '2', '3') <class 't ...

  8. Python学习笔记---切片 列表 元祖 字典 集合

    列表[1,2,3,2]#[] 元祖(1,2,3,2)#() 字典{1:2,3:2}#{} 集合{1,2,3,2}#{} 1,集合与列表的区别,集合里不能有重复元素 2.字典与集合的区别,都是用花括号表 ...

  9. python入门(五):切片列表元祖字典

    1.切片 针对序列,使用切片可以获得我们想要的内容 序列:字符串.列表.元祖 特点:可以使用坐标获取某一个值.坐标是从0开始算 >>> s="0123456789" ...

  10. python04 列表 元祖 字典

    1.list 有序,元素可以被修改 li=[1,2,2,"am","123"] 列表中的元素可以是数字,字符串,列表等等 支持切片,切片结果为列表  li[3] ...

随机推荐

  1. Job for nginx.service failed because the control process exited with error code. See “systemctl stat

    启动nginx服务时如果遇到这个错误 Job for nginx.service failed because the control process exited with error code. ...

  2. 实训23 功能FC的建立与调用

    第4章:实训23 功能的生成与条用 功能简称FC 是用户编写的没有自己存储区的逻辑块 . 功能主要用来执行条用一次就可以完成的操作. 类似于C语言中的 函数 步骤一 单击确定 以后 出现了 在下面图框 ...

  3. S7-200 smart 网线下载与调试配置

    打开 step microwin 7 smart 软件. 连接PLC 打开 通讯模块 我把电脑的改成了如下 我编写的简单的程序 通过外部一个开关 实现输出的一个 IO 的接通与断开 下载完成程序以后 ...

  4. Redis集群环境之linux搭建单机版

    Redis解决的问题是:作为一个缓存nosql数据库,能够支持高并发,关系型数据库是存储在磁盘中,通过io读写,而redis是存储在内存中,因此,能够实现高可用,他主要是解决数据库性能瓶颈而产生的. ...

  5. Web安全测试学习笔记 - vulhub环境搭建

    Vulhub和DVWA一样,也是开源漏洞靶场,地址:https://github.com/vulhub/vulhub 环境搭建过程如下: 1. 下载和安装Ubuntu 16.04镜像,镜像地址:htt ...

  6. 关于C#设计SQllite

    使用3.5框架+System.Data.SQLite,System.Data.SQLite.Ling+SQLite.Designer三个dll

  7. PHP笔记02

    PHP数组 能够在一个变量存储多个值 取值用下标,下标从0开始计算 好处:在处理物品清单等大量相同属性的变量内容时可以集中存取 <?php $arr=array("like" ...

  8. python+selenium 发送邮件

    import time from selenium import webdriver from selenium.webdriver import ChromeOptions from seleniu ...

  9. XSS跨站脚本攻击与CSRF跨站请求伪造攻击的学习总结(转载)

    转载自 https://blog.csdn.net/baidu_24024601/article/details/51957270 之前就了解过这方面的知识,但是没有系统地总结.今天在这总结一下,也让 ...

  10. String的Split使用方法(以特定字符分隔,提取所需信息)

    此处复制一串以空格分隔的数字,提取数字进行排序 int[] a = new int[10]; string input = Console.ReadLine();//获取用户输入的字符串 char[] ...