1、字典
 
       定义:字典是以 key :value 的形式来保存数据,用{} 来表示,存储的是 key : value
       查找效率比较高(注:字典存储数据时,用的是hash值来存储,算法不能变(python)
        数据必须是不可变的(可哈希),字典的key必须是可哈希的(不可变)
       
           列表是可变的,不可哈希
           元组是不可变的,可哈希的
 
2、字典的增删改查
 
    增加
 
        dic[新key] = 值
 
        dic.setdefault()  有添加的功能,如果key存在,不添加
        流程:判断新key是否在字典中存在,如果已经存在了,不做变更;如果不存在,执行添加操作
 
    删除
 
        dic.pop(key) 
        dic.popitem()  随机删除一项,在python早期的版本中,字典是无序的。
        del dic[key]    
        dic.clear()  清空
 
    修改
 
        dic[老key] = 值
        update(dic1)     # 把dic1中的内容更新到dic中,如果key重名,则修改替换,如果不存在key,则新增。
 
    查询 
 
        一般用key来查找具体的数据。
         1、直接使用key就可以拿到value。当key不存在时,报错  
         2、dic.get(key)  当key 不存在返回 None 
                                   当key存在时,返回第二个参数,默认第二个参数为 None
         3、 dic.setdefailt()  第一个功能是添加(当key不存在的时候)  第二个功能是查询(根据你给的key)
                整个执行流程:判断给的key是否存在,如果存在,就不执行新增流程,直接查询出这个key对应的value
                如果key不存在,先执行新增操作,再使用key把对应的value查询出来。
 
      遍历,字典是一个可迭代对象
            
            a,b = 1,2 # 把后面的两个值分别赋值给前面两个变量,解构,解包
            元组和列表是可以解包的
    for k,v in dic.items():
        print(item)
        k,v = item   #解构
        k = item[0]
        v = item[1]
        print(k,v)
 
            遍历字典的两套方案
      1、使用for循环直接遍历字典
dic = {"赵四":"刘晓光", "刘能":"王晓利", "王木生":"范伟"}
for key in dic:
print(key)
print(value)

  

   2、可以使用字典的items() +解构可以直接获取到key 和 value

for k,v in dic.items():
print(k)
print(v)

  

3、字典的相关操作
 
        dic.keys()  获取到所有的键值
        dic.values()  获取到所有的值
        dic.items()  获取到所有的键值对
 
4、字典的嵌套
 
        字典的嵌套,字典套字典
 
5、 set 集合
 
        set集合是python的一个基本数据类型。set中的元素是不重复的无序的,里面的元素必须是可hash的(int,str,tuple,bool)
        set 就是dic类型的数据但不保存value,只保存key set也用{}表示
 
        注: set集合中的元素必须是可hash的,但set本身是不可hash的,set是可变的
 
        使用set的不可重复的特性,我们可以使用set来去重  

# 给 list 去重
lst =[45,6,'geg',45,6]
lst = list(set(lst)) #把list转化成set,再转化回list
print(lst)

  

 
 6、set集合的增删改查
 
         1、增加
             s.add('元素')  # 重复的内容不会被添加到set集合中
 
             s.update('元素')   #迭代更新
 
          2、删除
    
             item = s.pop()   # 随机弹出一个
             s.remove('元素')   # 若这个元素不存在,删除在会报错
             s.clear()  #清空set集合,清空完之后,会打印为 set(),要和dic区分
 
         3、修改
 
            set集合中的数据没有索引,也没办法去定位一个元素,所以没有办法直接修改
            我们可以采用先删除后添加的方式来完成修改操作

s = {"刘嘉玲", '关之琳', "王祖贤","张曼⽟", "李若彤"}
# 把刘嘉玲改成赵本⼭
s.remove("刘嘉玲")
s.add("赵本⼭")
print(s)

  

  4、查询
 
             set 是一个可迭代的对象,所以可以进行for循环
 
 
7、set集合的一些其他操作
 
  交集:s1&s2   s1.intersection(s2)
  并集:s1|s2     s1.union(s2)
  差集 :s1 -s2    s1.difference(s2)     得到s1 中单独存在的元素
  反交集(s1^s2)   s1.symmetric_difference(s2)  两个集合中单独存在的元素
  子集:  s1 < s2    s1.issubset(s2)   s1 是 s2 的子集吗?返回  True  or  False
  超集: s1 >s2   s1 是s2 的超集吗? False  or  True
 
 
  set集合本身是可以发生改变的,是不可hash的。我们可以用frozenset来保存数据。frozenset是不可变的,也就是一个可哈希的数据类型 
s = frozenset(["赵本⼭", "刘能", "⽪⻓⼭", "⻓跪"])
dic = {s:'123'} # 可以正常使⽤了
print(dic) #{frozenset({'刘能', '⽪⻓⼭', '赵本⼭', '⻓跪'}): '123'}

  

python -- 字典 集合的更多相关文章

  1. python --->字典 集合 学习笔记

    1.字典--->创建空字典:dict={} broa=["李宁",”耐克“,“阿迪达斯”,“鱼c工作室”] sloga=[“A”,“B”,“C”,“D”] dict={&qu ...

  2. 3、Python字典集合

    2.3字典 字典是键值对的无序可变序列.键值之间用冒号隔开,相邻元素之间用逗号隔开,所有元素放在大括号之间{},键可以是Python中所有不可变的数据,不能用列表.元组.字典作为字典的键,键不可重复, ...

  3. Python字典和集合

    Python字典操作与遍历: 1.http://www.cnblogs.com/rubylouvre/archive/2011/06/19/2084739.html 2.http://5iqiong. ...

  4. Python学习笔记3-Python元组、数组、字典集合的操作

    在Python中数组中的每一项可以是不同的数据类型 元组:只能读不能写的数组 aTuple=(1,'abc','tmc',79.0,False) print aTuple[1:3] print typ ...

  5. python中列表 元组 字典 集合的区别

    列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计 ...

  6. **python中列表 元组 字典 集合

    列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. 1.列表 列表是以方括号“[]”包围的数据集合,不同成员以“,”分隔. 列表的特 ...

  7. Python 字典dict 集合set

    字典dict Python内置字典,通过key-value进行存储,字典是无序的,拓展hash names = ['Michael', 'Bob', 'Tracy'] scores = [95, 75 ...

  8. Python 高效编程技巧实战(2-1)如何在列表,字典, 集合中根据条件筛选数据

    Python 高效编程技巧实战(2-1)如何在列表,字典, 集合中根据条件筛选数据 学习目标 1.学会使用 filter 借助 Lambda 表达式过滤列表.集合.元组中的元素: 2.学会使用列表解析 ...

  9. 如何在列表,字典,集合中,根据条件筛选数据 -- Python数据结构与算法相关问题与解决技巧

    实际案例: 1.过滤掉列表 [3,9,-1,10,20,-2..]的负数 2.筛出字典{'LiLei':79,'Jim':88,'Lucy':92...}中值高于90的项 3.筛出集合 {77,89, ...

随机推荐

  1. 【LeetCode每天一题】Length of Last Word(字符串中最后一个单词的长度)

    Given a string s consists of upper/lower-case alphabets and empty space characters ' ', return the l ...

  2. vue 之iview

    iView-admin2.0:https://admin.iviewui.com/ 组件:https://www.iviewui.com/docs/guide/install

  3. windows----------windows查看端口是否被占用

    假如我们需要确定谁占用了我们的80端口在windows命令行窗口下执行: netstat -aon|findstr "80" TCP 127.0.0.1:80 0.0.0.0:0 ...

  4. .NET 4.5 中新提供的压缩类(转载)

    Windows8 的开发已经如火如荼开始了,在 Windows8 中提供的 .NET Framework 已经更新到了 4.5 版,其中又增加了一些新的特性,对压缩文件的支持就是其中之一. 在 4.5 ...

  5. Spring 部分常用注解

    最近在Spring-MVC的项目,把一些自己在项目中使用到的注解整理一下. 1.@Controller 对应表现层的Bean,也就是Struts中对应的Action: 使用这个注解之后,就是把当前Be ...

  6. .Net 多线程 (1) Task

    多线程是一种有效提高程序工作效率的方法.当然为了效率需要使用更多的cpu,内存等资源. 并发是两个队列交替使用一台咖啡机,并行是两个队列同时使用两台咖啡机,如果串行,一个队列使用一台咖啡机,那么哪怕前 ...

  7. hdu4777 树状数组

    题意:给了n个数,然后又m次查询,询问[L,R] 内有多少个数与其他的数不互质. 解: 我们首先可以通过处理得出每个数的有效区间,LR 就是 左边L位置上的数 和他不互质, 右边R位置上的数和不互质, ...

  8. mysql 终止 存储过程

    [1]如下图所示 有时候,存储过程执行语句中有循环,且已启动.但出于某种原因,我们突然不想让其再继续执行,需要终止其线程. Good Good Study, Day Day UP. 顺序 选择 循环 ...

  9. Spring 集成 Swagger UI

    <!-- Spring --> <dependency> <groupId>org.springframework.boot</groupId> < ...

  10. Centos下安装cassandra

    一.环境准备 环境 Centos6.5  .安装有Java JDK(https://www.cnblogs.com/wt645631686/p/8267239.html这篇文章里有安装JDK1.8的教 ...