python Day5

  • 字典

    • 其他数据类型的缺点

      • 列表可以存储大量的数据,但是关联性不强。
      • 列表的查询速度比较慢
    • 其容器的数据类型为dict

    • 其数据类型的分类

      • 可变(不可哈希)的数据类型:list dict set(集合)
      • 不可变(可哈希)的数据类型:str bool int tuple(不可操控原来的数据,都是建立一个新的字符串
    • 字典的格式

      • 字典:{}括起来,以键值对形式储存的容器数据类型

        dict1={"佛祖":
        {"name":"如来佛祖","sex":"男"}}
      • 字典是以key(键)和value(值)成对组成的,但是其键必须是不可变的数据类型组成的。(int,str 比较常用 bool tuple不常用)

      • 值可以是任意数据类型,对象

      • 字典3.5X版本之前(包括3.5)是无序的

      • 字典3.6X会按照初次建立字典的顺序排列,学术上不认为是有序排列的。

      • 3.7以后都是有序排列的

      • 字典优点:查询插入速度快,存储关联性的数据

      • 字典的缺点:以空间换时间(字典需要占用大量的内存,内存浪费多,其实使用hash算法通过key值计算需要查找位置的)

    • 字典的创建方式

      • 方法一

        dic=dict((("one",1),("two",2),("three",3)))
        print(dic)
        #结果:{'one': 1, 'two': 2, 'three': 3}
      • 方法二

        dic=dict(one=1,two=2,three=3)
        print(dic)
        #结果:{'one': 1, 'two': 2, 'three': 3}
      • 方法三(官方方法)

        dic=dict({"one":1,"two":2,"three":3})
        print(dic)
        #结果:{'one': 1, 'two': 2, 'three': 3}
  • 字典的增删改查

      • 方法一

        #如果初始的字典没有需要加入的key,则是真假,如果已经含有了key,重新赋值就是修改
        dic={"name":"如来佛祖","sex":"man"}
        dic['age']="无限"
        print(dic)
        #结果 {'name': '如来佛祖', 'sex': 'name', 'age': '限'}
      • 方法二

        dic={"name":"如来佛祖","sex":"man"}
        dic.setdefault("hobby","洗脑")
        print(dic)
        #结果 {'name': '如来佛祖', 'sex': 'name', 'hobby': '洗脑'}
    • 删 pop

      • 方法一 pop 同样能返回删除参数

        dic={"name":"如来佛祖","sex":"man"}
        ret=dic.pop("sex","没有此键")#设置第二个参数则无论字典中有无此键都不会报错
        print(dic)
        #结果 {'name': '如来佛祖'}
      • 方法二 clear 清空

        dic={"name":"如来佛祖","sex":"man"}
        ret=dic.clear()
        print(dic)
        #结果 {}
      • 方法三 del 没有pop好用,遇到字典中没有此键就会报错

        dic={"name":"如来佛祖","sex":"man "}
        del dic["sex"]
        print(dic)
        #结果 {'name': '如来佛祖'}
    • 改 在增加的地方已经说过

      • 方法一 通过key的提示将value值查找出来

        dic={"name":"如来佛祖","sex":"name","hobby_list":["假仁假义","大骗子","印度邪教"]}
        print(dic["hobby_list"])
        #结果 ['假仁假义', '大骗子', '印度邪教']
      • 方法二 get

        #get这个方法的获取更优势,理由同pop一样
        dic={"name":"如来佛祖","sex":"name","hobby_list":["假仁假义","大骗子","印度邪教"]}
        ls=dic.get("hobby_list")#同pop设置第二参数则字典有无此键都不会报错
        print(ls)
        #结果 ['假仁假义', '大骗子', '印度邪教']
      • 方法三 keys()

        #查出所有keys值
        #这个数字类型可以转化为列表
        dic={"name":"如来佛祖","sex":"name","hobby_list":["假仁假义","大骗子","印度邪教"]}
        print(dic.keys())
        #dict_keys(['name', 'sex', 'hobby_list'])
        #将其转化为列表
        dic={"name":"如来佛祖","sex":"name","hobby_list":["假仁假义","大骗子","印度邪教"]}
        print(list(dic.keys()))
        #结果 ['name', 'sex', 'hobby_list']
      • 方法四 items

        #将字典的keys和values值分别取出来,这里功能用到了元组的拆包
        dic={"name":"如来佛祖","sex":"name","hobby_list":["假仁假义","大骗子","印度邪教"]}
        for key,values in dic.items():
        print(key,values)
        #结果 name 如来佛祖
        # sex name
        # hobby_list ['假仁假义', '大骗子', '印度邪教']
  • 练习

    • 1.如content=input("输入内容:")用户输入 5+9+6 +12 +13然后进行计算

      content=input("请输入需要的内容:")
      list=content.split("+")
      result=0
      for i in list:
      result+=int(i)
      print(result)
    • 2.计算用户输入的内容中有几个整数(以个位数为单位)如:content=input("请输入内容:")如sfhlsdfh3445fdlsfh+=455f

      content=input("请输入需要的内容:")
      number=0
      for i in content:
      if i.isdecimal():
      number+=1
      print(number)
    • 3.判断一句话是否为回文。回文:正反念和反正念是一样的。列如,上海自来水来自海上

      content1=content[::-1]
      if content==content1:
      print("这是回文")
      else:
      print("这不是回文")
    • 4.找出li列表中的元素,移除每个(for)元素的空格,并找出一“A"或者”a"开头,并以"C"结尾的所有元素,并添加到一个新的列表中,最后循环打印这个列表。

      li=["TaiBai ","alexC","AbC ","egon","riTiAn","WuSir","aqc"]
      newli=[]
      for i in li:
      i1=i.strip()
      # if i1.startswith("A") or i1.startswith("a") and i1.endswith("C"):
      if i1.upper().startswith("A") and i1.endswith("C"):
      newli.append(i1)
      for j in newli:
      print(j)
    • 5.如下列表

      li=[1,3,4,"xiaoming",[3,7,8,"taiwan"],5]

      循环打印列表中的每个元素,遇到列表则再循环打印出它里面元素

      li=[1,3,4,"xiaoming",[3,7,8,"taiwan"],5]
      for i in li:
      if type(i)==list:
      for j in i:
      print(j)
      else:
      print(i)

python基础 Day5的更多相关文章

  1. Python基础Day5

    一.字典 ①字典是python的基础数据类型之一 ②字典可以存储大量的数据,关系型数据 ③字典也是python中唯一的映射类的数据类型 字典是以键值对的形式存在的,{键:值} 字典的键必须是不可变的数 ...

  2. 第五章:Python基础の生成器、迭代器、序列化和虚拟环境的应用

    本课主题 生成器介紹和操作实战 迭代器介紹和操作实战 序例化和反序例化 Json 和 Pickle 操作实战 字符串格式化的应用 创建虚拟环境实战 本周作业 生成器介紹和操作实战 什么是生成器,生成器 ...

  3. Python基础学习总结(持续更新)

    https://www.cnblogs.com/jin-xin/articles/7459977.html 嗯,学完一天,白天上班,眼睛要瞎了= = DAY1 1,计算机基础. CPU:相当于人的大脑 ...

  4. python基础-基础知识(包括:函数递归等知识)

    老男孩 Python 基础知识练习(三) 1.列举布尔值为 False 的值空,None,0, False, ", [], {}, () 2.写函数:根据范围获取其中 3 和 7 整除的所有 ...

  5. Python基础 小白[7天]入门笔记

    笔记来源 Day-1 基础知识(注释.输入.输出.循环.数据类型.随机数) #-*- codeing = utf-8 -*- #@Time : 2020/7/11 11:38 #@Author : H ...

  6. python之最强王者(2)——python基础语法

    背景介绍:由于本人一直做java开发,也是从txt开始写hello,world,使用javac命令编译,一直到使用myeclipse,其中的道理和辛酸都懂(请容许我擦干眼角的泪水),所以对于pytho ...

  7. Python开发【第二篇】:Python基础知识

    Python基础知识 一.初识基本数据类型 类型: int(整型) 在32位机器上,整数的位数为32位,取值范围为-2**31-2**31-1,即-2147483648-2147483647 在64位 ...

  8. Python小白的发展之路之Python基础(一)

    Python基础部分1: 1.Python简介 2.Python 2 or 3,两者的主要区别 3.Python解释器 4.安装Python 5.第一个Python程序 Hello World 6.P ...

  9. Python之路3【第一篇】Python基础

    本节内容 Python简介 Python安装 第一个Python程序 编程语言的分类 Python简介 1.Python的由来 python的创始人为吉多·范罗苏姆(Guido van Rossum) ...

随机推荐

  1. 题解 UVA1608 【不无聊的序列 Non-boring sequences】

    思路: 算法很显然: 一.在区间\([l,r]\)找到一个只出现一次的元素P(如果不存在,那么序列\(boring\)) 二.递归处理区间\([l,p-1]\)和区间\([p+1,r]\). 其关键在 ...

  2. 感性认识JWT

    常见的认证机制 今天我么聊一聊JWT. 关于JWT,相信很多人都已经看过用过,他是基于json数据结构的认证规范,简单的说就是验证用户登没登陆的玩意.这时候你可能回想,哎哟,不是又那个session么 ...

  3. js原声代码 轮播图

    js轮播图 html部分:建立div,内嵌img标签,可以设置大小, <!doctype html> <html> <head> <meta charset= ...

  4. SpringSecurity匹配规则介绍

    SpringSecurity匹配规则一 URL匹配 requestMatchers() 配置一个request Mather数组,参数为RequestMatcher 对象,其match 规则自定义,需 ...

  5. Vue数据产生变化需要页面渲染完之后执行某操作

    1.数据产生变化或者页面需要vue数据渲染完之后加载的东西 Vue.nextTick(function () { alert(123); }); 2 调用vue方法 --------------Vue ...

  6. pandas_学习的时候总会忘了的知识点

    对Series 对象使用匿名函数 使用 pipe 函数对 Series 对象使用 匿名函数 pd.Series(range(5)).pipe(lambda x,y,z :(x**y)%z,2,5) p ...

  7. 2-Numpy之hstack、vstack、concatenate区别

    concatenate与hstack.vstack的异同点: 都表示拼接数组,concatenate可以实现hstack和vstack的功能,只需要通过调整参数axis的值即可. 其中:v表示垂直(V ...

  8. ORACLE不完成恢复ORA-00392,ORA-00312,ORA-00349

    背景: 进行测试库不完全恢复,log_file_name_convert没调整好.rac-asm至单实例-文件系统,recover完成后,mount状态的database  执行 alter data ...

  9. Qt 乱码

    个人认识: 乱码的原因: 在编写代码时-->文件的格式--->编译器对文件进行编译的时候看到的只是二进制(乱码就出现在这里) 应合适方法 通知编译器(为什么说通知编译器呢?因为个人觉得这样 ...

  10. 数据分析学习 third week (7.29~8.4)

    概率分布简介 简单地介绍下常用概率分布的理论知识. 基础概念 1.概率 概率直观上是指一个事件发生可能性大小的数量指标 概率的统计定义:在不变的条件下,重复进行$n$次试验,事件$A$发生的频率稳定在 ...