python Day7

  • 基础数据类型的补充

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

      • bytes是一个数据类型

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

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

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

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

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

  • 作业

    • 看代码写结果

      1. v1=[1,2,3,4,5,6,7,8,9]
      2. v2={}
      3. for item in v1:
      4. if item<6:
      5. continue
      6. if "k1" in v2:
      7. v2["k1"].append(item)
      8. else:
      9. v2["k1"]=[item]
      10. print(v2)
      11. ####结果{'k1': [6, 7, 8, 9]}
      1. import copy
      2. v1=[1,2,3,4,5]
      3. v2=copy.copy(v1)
      4. v3=copy.deepcopy(v1)
      5. print(v1 is v2)
      6. print(v2 is v3)
      7. ###False False
      8. ###解释是无论深copy还是浅copy这个壳的地址都是不一样的
      1. import copy
      2. v1=[1,2,3,4,5]
      3. v2=copy.copy(v1)
      4. v3=copy.deepcopy(v1)
      5. print(v1[0] is v2[0])
      6. print(v2[0] is v3[0])
      7. ###True True
      8. ###无论是深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. freeRTOS内核学习笔记(1)-编程标准

    在开始具体的学习之前,你应该先了解freeRTOS的编程标准.这能够方便你在接下来的阅读中快速的了解一些内容 的基本信息,并方便记忆.此外,良好的编程风格也是工作效率的保障. 你可以在https:// ...

  2. Android存储--SharedPreferences

    简介 在Android中,主要有以下几种存储方式: SharedPreferences,在键值对中存储私有原始数据. 内部存储,在设备内存中存储私有数据. 官方示例: String FILENAME ...

  3. LQB2018A09倍数问题

    这个题,第一反应一定是三个for嵌套加一个max比较. 超级无敌大暴搜 #include <iostream> #include <string> #include <s ...

  4. 友好城市dp

    // // Created by Arc on 2020/4/27. //对了,这篇题解的代码是小白自己写的.有啥错误还请各位大佬多多包涵. /* * 某国有一条大河(一条大河~~~~,波浪宽~~~~ ...

  5. jupyter的服务器配置安装

    该教程主要针对的是服务器安装,且在后台保持稳定运行的情况. 1.jupyter下载 有网的时候 1. pip install jupyter 离线安装 在有网络的环境下载安装包 2. pip down ...

  6. mac下高效安装 homebrew 及完美避坑姿势 (亲测有效)

    世上无难事,只要找到 Homebrew 的正确安装方式. Homebrew 是什么 Homebrew是 mac的包管理器,仅需执行相应的命令,就能下载安装需要的软件包,可以省掉自己去下载.解压.拖拽( ...

  7. 菜鸟教程的 mysql-connector 基础

    安装驱动 python -m pip install mysql-connector 导包 import mysql.connector mydb = mysql.connector.connect( ...

  8. PHP natcasesort() 函数

    定义和用法 natcasesort() 函数用"自然排序"算法对数组进行排序.键值保留它们原始的键名. 在自然排序算法中,数字 2 小于 数字 10.在计算机排序算法中,10 小于 ...

  9. PHP mysqli_select_db() 函数

    更改连接的默认数据库: 删除数据库 <?php高佣联盟 www.cgewang.com // 假定数据库用户名:root,密码:123456,数据库:RUNOOB $con=mysqli_con ...

  10. CF R 633 div 1 1338 C. Perfect Triples 打表找规律

    LINK:Perfect Triples 初看这道题 一脸懵逼.. 完全没有思路 最多就只是发现一点小规律 即. a<b<c. 且b的最大的二进制位一定严格大于a b的最大二进制位一定等于 ...