python Day6

  • id 可以获得python的内存地址
    • id的举例子

      a=100
      print(id(a))
      #140712544153072 这里就是该对象的内存地址
    • is 判断的是比较内存地址是否相同

      #zhuxiayu
      ls=[1,2,3]
      ls1=[1,2,3]
      print(ls is ls1)
      str="zhuxiayu"
      str1="zhuxiayu"
      print(str is str1)
      #False
      #True
      • id相同,值一定相同
      • 值相同,id不一定相同
  • 代码块

    • 我们所有的代码都要依赖代码块执行。

    • 一个文件就是一个代码块

    • 交互式命令下一行就是一个代码块

    • 代码块的两个机制,同一个代码块下遵循同一个机制,不同的代码块下遵循的同一个机制。

    • 在同一个代码块内的缓存机制(字符串的驻留机制)

      • 目的:节省内存,提升性能。

      • 机制适用的对象:int bool str

      • 具体细则:所有的数字,bool值,几乎所有的字符串

      • 优点:提升性能,节省内存。

    • 不同代码块的缓存机制:小数据池

      • 前提条件:不同代码块
      • 适用对象: int bool str
      • 具体细则:-5~256的数字,bool,满足规则的字符串
  • python基本数据类型之:集合(容器型数据类型,它要求它里面的元素是不可变的)

    • 其本身是可变的数据类型。集合是无序的。

    • 集合的作用

      • 列表的去重

      • 关系测试:交集,并集,差集,.....

      • 空集合

        Set1=set()
      • 集合里面的元素必须是不可变的

    • 集合的增

      • add

        set1={1,4,"zhuxayu","ds"}
        set1.add("weew")
        print(set1)
        #{1, 4, 'ds', 'zhuxayu', 'weew'}
      • update

        #zhuxiayu
        set1={1,4,"zhuxayu","ds"}
        set1.update("weew")
        print(set1)
        #{1, 4, 'zhuxayu', 'e', 'w', 'ds'}
        #其可迭代的
    • 集合的删除-remove

      • pop随机删除
    • 集合的应用

      • 遇到取交集并集什么的(关系测试)

        #zhuxiayu
        #交集
        set1={1,2,3,4,5}
        set2={4,5,6,7,8}
        print(set1&set2)
        #并集
        print(set1|set2)
        #差集
        print(set1-set2)
      • 列表的去重

        #zhuxiayu
        li=[1,2,34,567,8,1,1,2,1,2,2]
        li1=set(li)
        li=list(li1)
        print(li)
  • 深浅copy

    • 浅copy(在拷贝的时候形成了两个地址)——全部切片属于浅copy

      l1=[1,2,34,567,8,1,1,2,1,2,2]
      l2=l1.copy()
      l1.append(66)
      print(l1)
      print(l2)
      #结果
      [1, 2, 34, 567, 8, 1, 1, 2, 1, 2, 2, 66]
      [1, 2, 34, 567, 8, 1, 1, 2, 1, 2, 2]
      • 注意在列表拷贝的时候大列表的地址是不一样的,但是里面的小列表的地址是一样的
      • 浅copy会在内存中新开辟一个空间,存放这个copy的列表,但是列表里面的内容还是沿用之前对象的内存地址l1,l2的id不同但是内容id相同
    • 深copy

      l1=[1,2,3,[1,2,2]]
      l2=copy.deepcopy(l1)
      这里的l1,l2是完全两个不同的地址了
      • python对copy做了一个优化,对可变的数据类型在内存中重新创建一份,而不可变的数据类型沿用之前的。
    • 浅copy:list,dict:嵌套的可变数据类型是同一个,深copy:list,dict嵌套的可变类型不是同一个

  • 作业

    • 作业1需求:

      • 页面显示序号+商品名称+商品价格
      • 用户如果输入选择的商品序号,然后打印商品名称及商品价格
      • 如果用户输入的商品序号有误,则提示输入有误,并重新输入
      • 用户输入Q,或者q,退出程序
      server = [
      {"name": "服务器1", "price": 10000},
      {"name": "服务器2", "price": 10500},
      {"name": "服务器3", "price": 10700},
      {"name": "服务器4", "price": 10800},
      ]
      while True: for index,dic in enumerate(server):
      print(index,dic["name"],dic["price"])
      number=input("请输入商品序号:").strip()
      if number.isdecimal():
      number=int(number)
      if 0<number<len(server):
      print(server[number-1]["name"],server[number-1]["price"])
      else:
      print("你输入的超出了范围")
      elif number.upper()=="Q": break
      else:
      print("你输入的为非法字典")
    • 作业2需求

      • dict={"name":"zhu","time":"fdsf",.}判断dict中“name"值是否在字典中

        dict={"name":"zhu","time":"fdsf"}
        print("name" in dict.keys())
    • 作业3需求

      • 循环提示用户,并将输入内容追加到列表中(如果输入N或n则停止循环)

        list=[]
        while 1:
        username=input("请输入用户名:")
        if username.upper()=="Q":break
        else:
        password=input("输入密码:")
        dic={}
        dic["name"]=username
        dic["password"]=password
        list.append(dic)
        print(list)
    • 作业4需求

      • 读出下列程序结果

        v1={"k1":"v1","k2":[1,2,3]}
        v2={"k1":"v1","k2":[1,2,3]}
        result=v1==v2
        result1=v1 is v2
        print(result,result1)
        #结果True False
        #因为不论是同代码的缓存机制还是小数据池缓存机制都只只用于bool int str三种数据类型
      • 读出下列的程序结果

        v1="dfsfsf"
        v2=[1,2,4,v1]
        v1="fsfdfsfsdfs"
        print(v2)
        #结果[1, 2, 4, 'dfsfsf']
        • 原因解释是这里是字符串,不可以变得数据结构,然后在V1赋值的时候相当于开辟了一个新的数值地址,因为不可变还是V2还是指向了v1运来值的地址
      • 读出下列的程序结果

        list=[]
        dict={}
        for i in range(10):
        dict["user"]=i
        list.append(dict)
        print(list)
        #结果[{'user': 9}, {'user': 9}, {'user': 9}, {'user': 9}, {'user': 9}, {'user': 9}, {'user': 9}, {'user': 9}, {'user': 9}, {'user': 9}]
        list=[]
        for i in range(10):
        dict = {}
        dict["user"]=i
        list.append(dict)
        print(list)
        #结果[{'user': 0}, {'user': 1}, {'user': 2}, {'user': 3}, {'user': 4}, {'user': 5}, {'user': 6}, {'user': 7}, {'user': 8}, {'user': 9}]
        • 解释,前面因为最后一步对字典进行了更改,后面因为每次添加的列表都是一个新的字典,所以数字不是重复的

python基础 Day6的更多相关文章

  1. Python基础Day6

    一.代码块 一个模块(模块就是py文件),一个函数,一个类,一个文件都是一个代码块,一个整体是一个代码块. 交互模式的每一行都是一个代码块(交互模式:命令提示符),相当于每行都在不同的文件 二.id ...

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

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

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

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

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

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

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

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

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

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

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

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

  8. 进击的Python【第三章】:Python基础(三)

    Python基础(三) 本章内容 集合的概念与操作 文件的操作 函数的特点与用法 参数与局部变量 return返回值的概念 递归的基本含义 函数式编程介绍 高阶函数的概念 一.集合的概念与操作 集合( ...

  9. 进击的Python【第二章】:Python基础(二)

    Python基础(二) 本章内容 数据类型 数据运算 列表与元组的基本操作 字典的基本操作 字符编码与转码 模块初探 练习:购物车程序 一.数据类型 Python有五个标准的数据类型: Numbers ...

随机推荐

  1. 重学c#系列——非托管实例(五)

    前言 托管资源到是好,有垃圾回收资源可以帮忙,即使需要我们的一些小小的调试来优化,也是让人感到欣慰的.但是非托管资源就显得苍白无力了,需要程序员自己去设计回收,同样有设计的地方也就能体现出程序员的设计 ...

  2. Python 为什么要有 pass 语句?

    本文出自"Python为什么"系列,请查看全部文章 关于 Python 中的pass语句,它似乎很简单(只有 4 个字母),即使是没有任何编程经验的初学者也能很快地掌握它的用法. ...

  3. LIMS/QMS产品索引

    Starlims https://www.cnblogs.com/mahongbiao/p/12863304.html 客户申请门户/客户服务门户 https://www.cnblogs.com/ma ...

  4. SAP四代增强实现:销售订单复制项目文本时不需要显示文本框和回车

    最近接收到一个业务需求,在SAP依据销售订单复制时,如果订单里面的项目有多个文本,系统就会显示复制的文本框处理,让用户选择是否复制,这个就让销售很不舒服,如果有几十个项目,每个项目有几个文本,那就就要 ...

  5. Python打印到屏幕_读取键盘输入

    Python打印到屏幕_读取键盘输入: print( ): 打印输出括号中的值 print("hello") # hello strs = 'hello' print(" ...

  6. PHP abs() 函数

    实例 返回不同数的绝对值: <?phpecho(abs(6.7) . "<br>");echo(abs(-6.7) . "<br>" ...

  7. PHP vsprintf() 函数

    实例 把格式化字符串写入变量中: <?php高佣联盟 www.cgewang.com$number = 9;$str = "Beijing";$txt = vsprintf( ...

  8. .NETCore中实现ObjectId反解

    前言 在设计数据库的时候,我们通常需要给业务数据表分配主键,很多时候,为了省事,我都是直接使用 GUID/UUID 的方式,但是在 MonggoDB 中,其内部实现了 ObjectId(以下统称为Oi ...

  9. 最后通牒!8月1日开始ios中国区下架全部无版号游戏

      据媒体报道,苹果早于7月8日就给中国游戏开发者发送邮件,要求游戏开发者必须在7月31日前提交游戏版号及相关文件,否则付费游戏将不可以在中国AppStore供应,8月1日期全部正式下架. ​   需 ...

  10. mybatis中的延迟查询思想

    1.一对一延迟加载 延迟加载: 就是在需要用到数据时才进行加载,不需要用到数据时就不加载数据.延迟加载也称懒加载. 好处:先从单表查询,需要时再从关联表去关联查询,大大提高数据库性能,因为查询单表要比 ...