zoukankan      html  css  js  c++  java
  • python===基本数据类型 基本增删改查 ===深浅拷贝==第七天

    将    列表======>字符串

      将  list     转化为    str

    e.g

      s="可口可乐"

      s1=s.join("非常可乐")     #  将s 放置到  非常可乐  中间

      print(s1)========>   非  可口可乐   常  可口可乐   可   可口可乐   乐  

      s="tx".join("ab") 

      print(s)=====>atxb

      s="_".join([  "alex","wusir","taibai" , "slary" ])

      print(s)=====>alex_wusir_taibai_slary

      lst=["我不是药神","西游记","天龙八部","后来"]

      lst.clear()====>[]     #将lst清空

      for el in lst:     #    在执行for循环的时候  内部有一个变量  index=0

                               index=index+1

                               因此,,,当删除完第" 0 "项的时候,  第" 1 "项会自动移动到"0"的位

                               置,  但是  index=index+1===>1了,所以,会继续删除现在在"1"项

                               的" 天龙八部 " ,原来在"2"的后来就跑到了"1",index=2,所以循环执行完毕,最后剩下    西游记   ,    后来                

        lst.remove(el)=======>"西游记","后来"    #  没有清空

      list  在循环列表的时候不能删,,,,,,,,因为会改变  索引位置

      在循环列表时删除  :

    e.g     删除姓周的人

      lst=["周杰伦","周润发","周星驰","麻花藤","周树人"]
      lst1=[]     #  创建一个空的列表   ,放置要删除的项
      for el in lst:     #遍历原来的列表
        if el.startswith("周"):      #   找到以  周  字开头的元素
          lst1.append(el)     #  将以周字开头的元素  添加到新列表中
      for el in lst1:      #   遍历新的列表    ,
        lst.remove(el)     ##    删除新列表在   原来列表中的元素    #  删除原来列表中姓周的元素
      print(lst)=========>    ["麻花藤"]

    字典在循环时,也不允许增加和删除

    dict.fromkeys()     是用dict 类  执行的.  

    dict.fromkeys()    不会对原来的字典产生影响,  因为  它会产生一个新的字典

     e.g

        dic={}

        dic.fromkeys("王健林","王思聪")

        print(dic)====>{}      #   对原来的字典不产生变化

        a=dic.fromkeys()  #将其定义

        print(a)====>{ "王": "思聪" ,  "健":  "思聪" , "林": "思聪"  }    #  新的字典

      e.g

        a=dict.fromkeys("麻花藤","ab")

        print(a)=====>{"麻": "ab", "花":"ab","藤":"ab"}

      

      a=dict.fromkeys([  "jj" ,  "jay"  ]  ,  "bd")

      print(a)======>{"jj": bd  , " jay ": "bd"  }

      

    类型转换

      像转换成啥,就用啥括起来

       元组   ====>   列表           list(  tuple  )

      列表  ====>   元组             tuple(  list  )

             列表   ====>字符串          str.join( list )

      字符串====> 列表                 str.split()

    set   集合 集合是基本的数据类型      

      s=set()    空集合     #    为了和字典区分

      元素:   不重复的   , 无序的   可hash的 (   不可变的    )    (  int    ,   str,      tuple    ,bool     )   

      set  就是  dict 字典类型的数据         ,但是不保存 value   只保存  key      ,  因此也用   { "  " , "  " , "  " }  表示

      set   元素是可hash的,  但是set本身是  不可hash 的,    因此set 本身是可以变得

        e.g

          s= {"王者刃",  "英雄" ,  123,   true   ,"英雄" ,  123}

          print(s)  ======>    {" 英雄 ",  123  ," 王者刃 " , true}

          s={ 123 ,  [  1,2,3 ] }

          print(s)  ====>   报错    =====>   list 是不可hash的

      set  集合  可帮助 去重复

        # 给list去重复

      lst = [45, 5, "哈哈", 45, '哈哈', 50]

      lst = list(set(lst))    # 把list转换成set, 然后再转换回list

      print(lst)====> [45, 5, "哈哈", 50]

    set集合增删改查

     1. 增加

        s = {"刘嘉玲", '关之琳', "王祖贤"}

        s.add("郑裕玲")

        print(s)  =====>{"刘嘉玲", '关之琳', "王祖贤","郑裕玲"}

        s.add("郑裕玲")          # 重复的内容不不会被添加到set集合中

        print(s) =======>{"刘嘉玲", '关之琳', "王祖贤","郑裕玲"}

      

      s = {"刘嘉玲", '关之琳', "王祖贤"}

      s.update("麻花藤")             # 迭代更新     

       print(s) =====>   {'花' ,  '关之琳',  '藤',   '刘嘉玲',      '王祖贤 '  ,  '麻'}

      s.update(["张曼⽟玉", "李李若彤","李李若彤"])   #   将列表内容 迭代加入

      print(s)   ======>    {'李若彤',    '藤',     '张曼玉',     '刘嘉玲',      '关之琳',     '花',    '王祖贤',    '麻'}

      2. 删除

        s = {"刘嘉玲", '关之琳', "王祖贤","张曼玉", "李若彤"}

        item = s.pop()    # 随机弹出⼀一个.   随机删除一个

        print(s)  =====>   {'刘嘉玲', '李若彤', '张曼玉', '关之琳'}

        print(item)=====>   王祖贤

        s = {"刘嘉玲", '关之琳', "王祖贤","张曼玉", "李若彤"}

        s.remove("关之琳")      # 直接删除元素

                    #        s.remove("⻢马⻁虎疼")        # 不不存在这个元素. 会报错

        print(s) =====> {'刘嘉玲', '张曼⽟玉', '李李若彤', '王祖贤'}

        s.clear()    # 清空set集合.需要注意的是set集合如果是空的.

               打印出来是set() 因为要和 dict区分的. print(s)    #

        =======>    set()

      3. 修改          set集合中的数据没有索引. 也没有办法去定位⼀一个元素. 所以没有办法进⾏行行直接修改.

      先  删除  要修改的元素

      再 添加  要改后的结果========>      修改

    e.g  

          s = {"刘嘉玲", '关之琳', "王祖贤","张曼玉", "李若彤"}

          # 把刘嘉玲改成赵本山

        s.remove("刘嘉玲")

        s.add("赵本⼭山")

        print(s)========> {'赵本山', '张曼玉', '王祖贤', '李若彤', '关之琳'}

      4. 查询

        # set是⼀一个可迭代对象.

        所以可以进⾏行行for循环

        for el in s:   

          print(el)

      5. 常⽤用操作
        s1 = {"刘能", "赵四", "皮长山"}

        s2 = {"刘科长", "冯乡长", "皮长山"}

          # 交集           # 两个集合中的共有元素

        print(s1 & s2)   =======>     {'皮长山'}

        print(s1.intersection(s2))  # {'皮长山'}

          # 并集
        print(s1 | s2)      ======>   #      { '刘科长', '冯乡长', '赵四', '皮长山', '刘能'}

        print(s1.union(s2))  =====>      #         {'刘科长', '冯乡长', '赵四', '皮长山', '刘能'}

          # 差集

         print(s1 - s2)     =====> #      {'赵四', '刘能'}         得到第⼀一个中单独存在的

        print(s1.difference(s2))   ======>    # {'赵四', '刘能'}    得到第⼀一个中单独存在的

          # 反交集

        print(s1 ^ s2)  ====>      # 两个集合中单独存在的数据        {'冯乡长', '刘能', '刘科长', '赵四'}

        print(s1.symmetric_difference(s2)) ====>    两个集合中单独存在的数据     # {'冯乡长', '刘能', '刘科长', '赵四'}

        

        s1 = {"刘能", "赵四"}

        s2 = {"刘能", "赵四", "⽪皮⻓长⼭山"}

          # 子集

         print(s1 < s2)    #    set1是set2的⼦子集吗?         判断s1   是否是  s2 的子集   ====>    True

         print(s1.issubset(s2))====>  True

          # 超集

         print(s1 > s2)      # set1是set2的超集吗?      False

        print(s1.issuperset(s2))=====>   False

      set集合本⾝身是可以发⽣生改变的. 是不可hash的.

      我们可以使⽤用frozenset来保存数据.        frozenset是不可变的.     也就是⼀一个可哈希的数据类型

    e.g

      s = frozenset([1,2,6,6,8,7,9,7])    #   列表是不可hash的,  只有变成 可hash 才会放入其中

      print(s)=====>  frozenset([6,2,1,8,9,7])

      ss={"a", s}

      print(ss) ====>{ "a",    frozenset([6,2,1,8,9,7])  }

    三. 深浅拷贝

      lst1 = ["⾦金金⽑毛狮王", "紫衫⻰龙王", "⽩白眉鹰王", "⻘青翼蝠王"]

      lst2 = lst1    #  进行赋值操作    ,实际上是引用内存地址的赋值,    内存中此时  只有一个  列表

                  两个变量   指向的是一个列表

         

      print(lst1) =====> ["⾦金金⽑毛狮王", "紫衫⻰龙王", "⽩白眉鹰王", "⻘青翼蝠王"]

      print(lst2) ====> ["⾦金金⽑毛狮王", "紫衫⻰龙王", "⽩白眉鹰王", "⻘青翼蝠王"]

      lst1.append("杨逍")     #     由于两个变量指向的是同一个   列表,  因此   一个改变   两个都会改变

      print(lst1)  =====>  ['⾦金金⽑毛狮王', '紫衫⻰龙王', '⽩白眉鹰王', '⻘青翼蝠王', '杨逍']

      print(lst2)   ====>   ['⾦金金⽑毛狮王', '紫衫⻰龙王', '⽩白眉鹰王', '⻘青翼蝠王', '杨逍']

      e.g    

      lst1=["赵本山","刘能","小沈阳"]
      lst2=lst1
      lst2.append("赵四")
      print(lst1)=====>   ['赵本山', '刘能', '小沈阳', '赵四']
      print(lst2)=====>   ['赵本山', '刘能', '小沈阳', '赵四']
      print(id(lst1))=====>48849584
      print(id(lst2))======>  48849584

    浅拷贝

        浅拷贝. 只会拷贝第一层. 第二层的内容不会拷贝. 所以被称为浅拷贝

      拷贝后.内存地址会发生变化,   因此是两个不同的对象

      e.g   

        lst3=["赵本山","刘能","小沈阳"]
        lst4=lst3.copy()     将原来的列表3,copy了一个,  内存地址变了,    变量指向的是两个对象,  不是一个,,

                因此,改变一个,另一个不变

        lst4.append("谢大脚")
        print(lst3)    ======>   ['赵本山', '刘能', '小沈阳']
        print(lst4)   =====>  ['赵本山', '刘能', '小沈阳', '谢大脚']
        print(id(lst3))   ====>59794096
        print(id(lst4)) ====>59794056

    深拷贝

      e.g

        lst1 = ["何炅", "杜海海涛","周渝⺠民", ["麻花藤", "⻢马芸", "周笔畅"]]

        lst2 = lst1.copy()   # 将lst1 copy 出来一个, 表面 的列表是两个,,但是两个列表  包含的内部的列表,她两指向的是   同

                  一个内部列表,,,,因此内部的列表改变的话,外边两个整体指的是   同一个内部表    因此,内部改

                  变两个都会变                   

        lst1[3].append("无敌是多磨寂寞")

        print(lst1) ======>  ['何炅', '杜海海涛', '周渝⺠民', ['麻花藤', '⻢马芸', '周笔畅', '无敌是多磨寂寞']]

         print(lst2)  =====>  ['何炅', '杜海海涛', '周渝⺠民', ['麻花藤', '⻢马芸', '周笔畅', '无敌是多磨寂寞']]

         print(id(lst1[3]) ====>  50029232

        printid(lst2[3]))  ====>  50029232

     深拷贝

      e.g

        import copy

          lst1 = ["何炅", "杜海海涛","周渝⺠民", ["麻花藤", "⻢马芸", "周笔畅"]]

        lst2 = copy.deepcopy(lst1)      #  把lst1 扔进去进行  深度拷贝   ,

                      将里边嵌套的所有东西,,都拷一份,就成为两个对象了,   两个  内存地址

        lst1[3].append("⽆无敌是多磨寂寞")

          print(lst1)  ===>   ['何炅', '杜海海涛', '周渝⺠民', ['麻花藤', '⻢马芸', '周笔畅', '⽆无敌是多磨寂寞']] 

        print(lst2)  =====.>['何炅', '杜海海涛', '周渝⺠民', ['麻花藤', '⻢马芸', '周笔畅']]

        print(id(lst1[3]))  =====>   4447221448

        print(id(lst2[3]))  ====>   4447233800

      

      

  • 相关阅读:
    HTTP协议
    JavaScript学习(一)
    Cookie&Session
    注解初学
    反射初学
    XML
    Web概念
    Response对象
    Servlet
    LeetCode Notes_#617 Merge Two Binary Trees
  • 原文地址:https://www.cnblogs.com/lynysy/p/9289229.html
Copyright © 2011-2022 走看看