python Day7

  • 基础数据类型的补充

    • str的数据类型补充
      • capitalize函数将首字母大写,其余变小写

        s1="taibei"
        print(s1.capitalize())
        ###结果TaiBei
      • swapcaseh函数将大小写反转

        s1="taibei"
        print(s1.swapcaseh())
        ###结果TAIBEI
      • title函数是每个单词的首字母大写

        s1="zhu xia yu "
        print(s1.title())
        ###结果Zhu Xia Yu
      • center函数是将字符串居中

        s1="zhuxiayu"
        print(s1.center(20,"*"))
        ###结果******zhuxiayu******
      • find 函数是通过元素找索引,找到第一个就返回,找不到返回-1

        s1="Dsfs"
        print(s1.find("s"))
        print(s1.find("o"))
        ###结果1
        ##-1
      • index函数是通过元素找索引,找到第一个就返回,找不到就报错

        s1="Dsfs"
        print(s1.index("s"))
        print(s1.index("o"))
    • tuple的数据类型补充
      • 元组中如果只有一个元素,并且没有都好,那么它不是元组,它与该元素的数据类型一致

        s=(1,)
        print(s,type(s))
        ###结果(1,) <class 'tuple'>
      • count函数是统计元组的个数

        tu=(1,2,4,3,4,44,2)
        print(tu.count(2))
        ###结果 2
    • list的数据类型补充
      • sort排序,默认从小到大

        list=[1,12,4,5,5]
        list.sort()#默认从小到大的排序
        print(list)
        list.sort(reverse=True)#默认从大到小的排序
        ###[1, 4, 5, 5, 12]
      • 循环一个列表的时候,最好不要改变列表的大小,这样会影响你最终的结果

    • dict的数据类型补充
      • 可以通过update的形式增加键值队伍(这部分经常考)

        dict={"name":"zhuxiayu","age":12}
        dict.update(hobby="basketball")
        print(dict)
        ###{'name': 'zhuxiayu', 'age': 12, 'hobby': 'basketball'}
        dict={"name":"zhuxiayu","age":12}
        dict.update([("a",1),("zhuxiayu","dsfsfs")])
        print(dict)
        ###{'name': 'zhuxiayu', 'age': 12, 'a': 1, 'zhuxiayu': 'dsfsfs'}
        dict={"name":"zhuxiayu","age":12}
        dict1={"name":"sunchnagay","hobby":"basteketball"}
        dict.update(dict1)
        print(dict1)
        ####{'name': 'sunchnagay', 'hobby': 'basteketball'}
      • fromkeys函数中字典的键是一个可迭代对象

        dict=dict.fromkeys("zhuxiayu",1000)
        print(dict)
        ###{'z': 1000, 'h': 1000, 'u': 1000, 'x': 1000, 'i': 1000, 'a': 1000, 'y': 1000}
        • 坑:在迭代中共用一个列表

          dict=dict.fromkeys([1,2,3], [])
          dict[1].append(666)
          print(dict)
          ###{1: [666], 2: [666], 3: [666]}
      • 循环一个字典时,如果改变这个字典的大小,就会报错。

        #删除字典里面带k的值
        dict={"k1":"太白","k2":"dsfs","k3":"barkky","age":18}
        li=[]
        for key in dict.keys():
        if "k"in key:
        li.append(key)
        for i in li:
        dict.pop(i)
        print(dict)
        ###{'age': 18}
    • 所有的数据都可以转化为bool值
    • 按照存储空间对数据类型的划分
      • 数字
      • 字符串
      • 集合:无序:即无序索引相关信息
      • 元组:有序,需要索引相关信息,不可变
      • 列表:有序,需要索引相关信息,可变,需要处理数据的增删改
      • 字典:有序,需要存key与value映射关系信息,可变,需要处理数据的增删
  • 编码的进阶

    • 数据在列表中全部是以Unicode编码的,但是当你的数据用于网络传输或者存储到硬盘中,必须以非Unicode编码(utf-8,gbk等等)

      • bytes是一个数据类型

        eg:"今晚吃鸡",内部编码形式是:Unicode,表现形式:“今晚吃鸡“

        ​ 转化为bytes类型,内部编码形式是非Unicode,表现形式:"今晚吃鸡"

        msg="我哎中国"
        msg1=msg.encode("utf-8")
        print(msg1)
        msg=msg1.decode("utf-8")
        print(msg)
        ###结果b'\xe6\x88\x91\xe5\x93\x8e\xe4\xb8\xad\xe5\x9b\xbd'
        ###我哎中国
      • 从uft-8转化为gbk

        msg=b'\xe6\x88\x91\xe5\x93\x8e\xe4\xb8\xad\xe5\x9b\xbd'
        msg1=msg.decode("utf-8")
        msg1=msg1.encode("gbk")
        print(msg1)
        ###b'\xce\xd2\xb0\xa5\xd6\xd0\xb9\xfa'
      • 在内存中所有的数据必须是unicode编码存在,出去bytes

      • str与bytes的区别为前者为文字文本,后者为字节文本

  • 作业

    • 看代码写结果

      v1=[1,2,3,4,5,6,7,8,9]
      v2={}
      for item in v1:
      if item<6:
      continue
      if "k1" in v2:
      v2["k1"].append(item)
      else:
      v2["k1"]=[item]
      print(v2)
      ####结果{'k1': [6, 7, 8, 9]}
      import copy
      v1=[1,2,3,4,5]
      v2=copy.copy(v1)
      v3=copy.deepcopy(v1)
      print(v1 is v2)
      print(v2 is v3)
      ###False False
      ###解释是无论深copy还是浅copy这个壳的地址都是不一样的
      import copy
      v1=[1,2,3,4,5]
      v2=copy.copy(v1)
      v3=copy.deepcopy(v1)
      print(v1[0] is v2[0])
      print(v2[0] is v3[0])
      ###True True
      ###无论是深copy还是浅copy,外壳的地址都是一样的,里的内容如果是不可变数据类型其公用的是一个地址。里面的内容是可变数据类型,则深拷贝就要重新开辟地址。

python基础 Day7的更多相关文章

  1. Python基础Day7

    七步记忆法: ① 预习(30min) ② 听课 (重点) ③ 课间练习 ④ 下午或者晚上练习(大量练习.重复练习)⑤ 晚上睡觉前的回忆 ⑥ 第二天早晨回顾 ⑦ 每周总结,自己默写方法 一.enumer ...

  2. Day7 - Python基础7 面向对象编程进阶

    Python之路,Day7 - 面向对象编程进阶   本节内容: 面向对象高级语法部分 经典类vs新式类 静态方法.类方法.属性方法 类的特殊方法 反射 异常处理 Socket开发基础 作业:开发一个 ...

  3. Python自动化 【第七篇】:Python基础-面向对象高级语法、异常处理、Scoket开发基础

    本节内容: 1.     面向对象高级语法部分 1.1   静态方法.类方法.属性方法 1.2   类的特殊方法 1.3   反射 2.     异常处理 3.     Socket开发基础 1.   ...

  4. python基础——内置函数

    python基础--内置函数  一.内置函数(python3.x) 内置参数详解官方文档: https://docs.python.org/3/library/functions.html?highl ...

  5. Python基础7 面向对象编程进阶

    本节内容: 面向对象高级语法部分 经典类vs新式类 静态方法.类方法.属性方法 类的特殊方法 反射 异常处理 Socket开发基础 作业:开发一个支持多用户在线的FTP程序 面向对象高级语法部分 经典 ...

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

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

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

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

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

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

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

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

随机推荐

  1. 完成的设备扫描项目的几个关键程序,包括activity之间的转换

    module 的 gradle.build最后三行的compile 是关键dependencies { implementation fileTree(dir: 'libs', include: [' ...

  2. python基础--面向对象基础(类与对象、对象之间的交互和组合、面向对象的命名空间、面向对象的三大特性等)

    python基础--面向对象 (1)面向过程VS面向对象 面向过程的程序设计的核心是过程(流水线式思维),过程即解决问题的步骤,面向过程的设计就好比精心设计好一条流水线,考虑周全什么时候处理什么东西. ...

  3. [转载]Android SDK 离线文档 (api 20)(升级至api 23)

    原文地址:SDK 离线文档 (api 20)(升级至api 23)">Android SDK 离线文档 (api 20)(升级至api 23)作者:leechenhwa Android ...

  4. Day01_WebCrawler(网络爬虫)

    学于黑马和传智播客联合做的教学项目 感谢 黑马官网 传智播客官网 微信搜索"艺术行者",关注并回复关键词"webcrawler"获取视频和教程资料! b站在线视 ...

  5. Upload 上传 el-upload 上传配置请求头为Content-Type: "multipart/form-data"

    api接口处添加属性 (标红处) // 校验台账 export const checkEquiment = (data) => { return axios({ url: '/job/equip ...

  6. PHP is_link() 函数

    定义和用法 The is_link() 函数检查指定的文件是否是一个连接. 如果文件是一个连接,该函数返回 TRUE. 语法 is_link(file) 参数 描述 file 必需.规定要检查的文件. ...

  7. Skill 脚本演示 ycBusNet.il

    https://www.cnblogs.com/yeungchie/ ycBusNet.il 用于原理图中按照一定格式,批量创建 Bus . 回到目录

  8. linux的文件处理(匹配 正则表达式 egrep awk sed)和系统、核心数据备份

    文件处理 1.处理方式 匹配 正则表达式 egrep awk sed 2.文件中的处理字符 \n  新行符 换行 \t  制表符 tab键 缺省8个空格 \b  退格符 backspace键 退格键 ...

  9. Dropwizard+jersey+MDC实现日志跟踪以及接口响应时间统计

    一.实现接口响应时间统计 1.1添加全局请求过滤器并注册 import org.apache.log4j.MDC; import org.slf4j.Logger; import org.slf4j. ...

  10. Linux进程间通信之《共享内存》入门

    目录 简述 代码 写端代码 读取端代码 编译 运行 简述 共享内存是Linux系统进程间通信常用的方式,通常用于数据量较大的情况,如果只是用于不同的进程间消息通知,那不如用消息队列或者socket.之 ...