一:元组

    1)定义

    元组:有序,可以按索引取值,不可变,但是可以修改元组里面可变数据的数据内容。

    res = (1,2,3,4,3,2,1)

  2)内置方法和使用

    res.count(1)

    返回值:2

  

    可以count,说明可以存放多个同样的数据

    res.index(2,3,6)

    返回值:5

二:字典

  1)字典的定义:

    字典无序,可以按key取值,key可以为所有不可变类型的数据,values可以为所有类型数据。

    例:name={"one":"wusong","two":"likui","three":"ruanxiaoqi","four":"songjiang"}

  2)字典的内置方法和使用

    1.取值

      常用取值为key,但是当key不存在于字典中时,会报错

      name.get(key)

      如果不存在于字典,则返回None,若存在,则返回value

    

    2.keys,values,items

      

name={"one":"wusong","two":"likui","three":"ruanxiaoqi","four":"songjiang"}

print(name.keys(),type(name.keys()))
#返回值:dict_keys(['one', 'two', 'three', 'four']) <class 'dict_keys'> print(name,values(),type(name.values()))
#返回值:dict_values(['wusong', 'likui', 'ruanxiaoqi', 'songjiang']) <class 'dict_values'> print(name.items(),type(name.items()))
#返回值:dict_items([('one', 'wusong'), ('two', 'likui'), ('three', 'ruanxiaoqi'), ('four', 'songjiang')]) <class 'dict_items'> #三种方式的返回值都不是原生列表,无法直接按索引取值,但是可疑的通过for迭代取出,或者直接强制转换为list类型,再按照索引取出。

    3.增加包含的值

      ①update

      ②setdefault

name={"one":"wusong","two":"likui","three":"ruanxiaoqi","four":"songjiang"}

name.update({"four":"sunerniang","five":"ruanxiaoer"})
print(name)
#返回值:{"one":"wusong","two":"likui","three":"ruanxiaoqi","four":"sunerniang","five":"ruanxiaoer"}
#遵从:原来字典有相同key则覆盖,无则添加。 name={"one":"wusong","two":"likui","three":"ruanxiaoqi","four":"songjiang"}
name.setdefault("five",None)
print(name)
#返回值:name={"one":"wusong","two":"likui","three":"ruanxiaoqi","four":"songjiang","five":None}
#原先字典有的key则忽视更新,没有的key则按第二个参数为value创建 name.fromkeys(["six","seven"],None)
#不改变字典里面的值,若为空字典,则迭代取出key,value为None

    4.去值

name={"one":"wusong","two":"likui","three":"ruanxiaoqi","four":"songjiang"}
pop_data=name.pop("two")
print(pop_data,name)
#返回值:likui {'one': 'wusong', 'three': 'ruanxiaoqi', 'four': 'songjiang'}
#pop按key弹出值,有返回值。
pop_data2=name.popitems()
print(pop_data2)
#返回值:('four', 'songjiang')
#popitems默认弹出最右的item,有返回值。

三:集合

  1)set集合的定义

    1.为单列数据集合(常见单列数据集合有:list,str,tuple,set,双列数据集合:dict)

    2.无序无key,无法取值

    3.可变数据,内部可以存放任意类型的多个数据,但是数据具有唯一性

  2)内置方法与使用

    1.交集,&,intersection

    2.并集,|,union

    3.差集,-,difference

    4.对称差集,^,symmetric_difference

a={1,2,3,4,5}
b={3,4,5,6,7} print(a.intersection(b))
print(a&b)
#返回值:{3, 4, 5} print(a.union(b))
print(a|b)
#返回值:{1, 2, 3, 4, 5, 6, 7} print(a.difference(b))
print(a-b)
#返回值:{1, 2} print(a.symmetric_difference(b))
print(a^b)
#返回值:{1, 2, 6, 7}

    在所有的运算后加_update就变为了替换原有数据,更新列表

   5.父子集合

a={1,2,3}
b={2,3,}
print(a>b)
print(a<b)
print(a==b) #返回值:True
False
False

python全栈开发_day6_元组,字典,集合的更多相关文章

  1. python全栈开发-Day5 元组、字典

    python全栈开发-Day5  元组.字典 一.前言 首先,不管学习什么数据类型,我们都带着以下几个问题展开学习: #1:基本使用 1 .用途 2 .定义方式 3.常用操作+内置的方法 #2:该类型 ...

  2. python全栈开发笔记---------数据类型---字典方法

    def clear(self) 清空字典里所有元素 # info = { # "k1":18, # "k2":True, # "k3":[ ...

  3. python 全栈开发,Day5(字典,增删改查,其他操作方法)

    一.字典 字典是python中唯一的映射类型,采用键值对(key-value)的形式存储数据.存储大量的数据,是关系型数据,查询数据快. 列表是从头遍历到尾字典使用二分查找 二分查找也称折半查找(Bi ...

  4. python全栈开发笔记---------数据类型-----字典dict

    字典 #dict #1.基本结构 info= { "k1" : "v1", #键值对 "k2" : "v2" } ### ...

  5. Python 全栈开发:dict(字典)常用方法操作、dict嵌套

    数据类型的划分:可变数据类型和不可变数据类型. 不可变数据类型(可哈希):元祖.bool.int.str 可变数据类型(不可哈希):list.dict,set(集合) dict(字典): dict(字 ...

  6. Python全栈开发 列表, 元组 数据类型知识运用及操作 range知识

    一.列表 1.什么是列表? 列表是一个可变类型,由  [ ] 表示,每一项元素用逗号隔开.列表能够装大量的数据,可以装对象的对象. 2.列表的索引和切片. 列表和字符串一样,也有索引和切片.只不过列表 ...

  7. python全栈开发学习_内容目录及链接

    python全栈开发学习_day1_计算机五大组成部分及操作系统 python全栈开发学习_day2_语言种类及变量 python全栈开发_day3_数据类型,输入输出及运算符 python全栈开发_ ...

  8. Python全栈开发【模块】

    Python全栈开发[模块] 本节内容: 模块介绍 time random os sys json & picle shelve XML hashlib ConfigParser loggin ...

  9. Python全栈开发【基础四】

    Python全栈开发[基础四] 本节内容: 匿名函数(lambda) 函数式编程(map,filter,reduce) 文件处理 迭代器 三元表达式 列表解析与生成器表达式 生成器 匿名函数 lamb ...

随机推荐

  1. [C++] Memory_stack_heap

    STACK_HEAP_MEMERY_MAP NOTICE: For p1 , where is the address of p1 ?(0x200400) IN STACK For p1 , wher ...

  2. LA3983 捡垃圾的机器人

    Problem C - Robotruck Background This problem is about a robotic truck that distributes mail package ...

  3. [模板]单源最短路径(Dijkstra)

    如题,给出一个有向图,请输出从某一点出发到所有点的最短路径长度. 主要还是再打一遍最短路,这种算法我用的不多... #include<bits/stdc++.h> using namesp ...

  4. back propogation 的线代描述

    参考资料: 算法部分: standfor, ufldl  : http://ufldl.stanford.edu/wiki/index.php/UFLDL_Tutorial 一文弄懂BP:https: ...

  5. 认证服务号Thinkphp微信支付

    公众号配置 1.微信支付过程中需要获取用户的openid,所以,仍需填写 网页授权域名 2.微信支付授权目录  Thinkphp目录格式为www.xxx.cn/home/wxpay/ 这里目录不能填写 ...

  6. 编写高质量代码改善C#程序的157个建议——建议76: 警惕线程的优先级

    建议76: 警惕线程的优先级 线程在C#中有5个优先级:Highest.AboveNormal.Normal.BelowNormal和Lowest.讲到线程的优先级,就会涉及线程的调度.Windows ...

  7. select,poll,epoll用法

    http://blog.csdn.net/sunboy_2050/article/details/6126712 select用法 #include <sys/time.h>       ...

  8. 实用的chrome插件

      有人说Chrome是世界上最好的浏览器,当然也会有不赞同.但不论怎样,工具而已,何必限制,任何一个用好了都能迅速提高我们的效率,不过还是推荐Chrome. 自然问题就变成:“为什么要用Chrome ...

  9. Java NIO学习-详细内容(一)

    一.三大类 1.Channels FileChannel DatagramChannel SocketChannel ServerSocketChannel 2.Selector与SelectionK ...

  10. Replication--镜像+复制

    场景:主服务器:Server1从服务器:Server2订阅服务器: Server3镜像DB: RepDB配置:1>配置SERVER3为分发服务器,在Server3上指定发布服务器SERVER1和 ...