• Python基础数据类型二


    Python基础数据类型二

    一.列表

    列表是python的基础数据类型之一 ,其他编程语言也有类似的数据类型.

    比如JS中的数 组, java中的数组等等. 它是以[ ]括起来, 每个元素用' , '隔开而且可以存放各种数据类型:

    列表是python中的基础数据类型之一,其他语言中也有类似于列表的数据类型,比如js中叫数组,他是以[]括起来,每个元素以逗号隔开,而且他里面可以存放各种数据类型比如:

    li = [‘alex’,123,Ture,(1,2,3,’wusir’),[1,2,3,’小明’,]]
    

    列表相比于字符串,不仅可以储存不同的数据类型,而且可以储存大量数据,

    32位python的限制是 536870912 个元素,

    64位python的限制是 1152921504606846975 个元素。而且列表是有序的,有索引值,可切片,方便取值。

    lst = [1,2,3,"alex",[1,2,3]]
    

    我们定义了一个列表,我们现在来看看内存中是怎样存储的

    image-20190624212151009

    lst我们就可以想象成一个书包,书包中存放了衣服,电脑,书,钱包,钱包中放的是身份证,公交卡,家门钥匙

    1.1 列表的索引

    列表和字符串一样也拥有索引:

    lst = ['刘德华','周润发','周杰伦','向华强']
    print(lst[0])  # 列表中第一个元素
    print(lst[1])  # 列表中第二个元素
    print(lst[2])  # 列表中第三个元素
    

    注意:列表是可以进行修改的,这里和字符串不一样

    lst[3] = '王健林'
    print(lst)
    

    字符串修改

    s = '王思聪'
    s[0] = '李'
    print(s)
    结果:
    Traceback (most recent call last):
      File "D:/python_object/path2/test.py", line 1076, in <module>
        s[0] = '李'
    TypeError: 'str' object does not support item assignment
    

    1.2 列表的切片

    lst = ["麻花藤", "王剑林", "马芸", "周鸿医", "向华强"] 
    print(lst[0:3])     # ['麻花藤', '王剑林', '马芸'] 
    print(lst[:3])      # ['麻花藤', '王剑林', '马芸']
    print(lst[1::2])    # ['王剑林', '周鸿医'] 也有步长 
    print(lst[2::-1])   # ['马芸', '王剑林', '麻花藤'] 也可以倒着取 
    print(lst[-1:-3:-2])    # 倒着带步长
    

    练习

    li = [1, 3, 2, "a", 4, "b", 5,"c"]
    通过对li列表的切片形成新的列表l1,l1 = [1,3,2]
    通过对li列表的切片形成新的列表l2,l2 = ["a",4,"b"]
    通过对li列表的切片形成新的列表l3,l3 = ["1,2,4,5]
    通过对li列表的切片形成新的列表l4,l4 = [3,"a","b"]
    通过对li列表的切片形成新的列表l5,l5 = ["c"]
    通过对li列表的切片形成新的列表l6,l6 = ["b","a",3]
    

    1.3 列表的增删改查

    1.3.1 增

    注意 list和str是不一样的. lst可以发生改变. 所以直接就在原来的对象上进行了操作

    追加模式

    lst = ["麻花藤", "林俊杰", "周润发", "周芷若"] 
    print(lst) 
    lst.append("wusir") 
    print(lst)
    

    练习

    输入用户信息,添加到列表中

    lst = []
    while True:
        content = input("请输入你要录入的员工信息, 输入Q退出:")
        if content.upper() == 'Q':
            break
    lst.append(content)
    print(lst)
    

    插入模式

    lst = ["麻花藤", "张德忠", "孔德福"]
    lst.insert(1, "刘德华")    # 在1的位置插入刘德华. 原来的元素向后移动一位
    print(lst)
    

    迭代添加

    # 迭代添加
    lst = ["王志文", "张一山", "苦海无涯"]
    lst.extend(["麻花藤", "麻花不疼"])
    print(lst)
    

    1.3.2 删除

    pop 通过下标删除元素(默认删除最后一个)
    
    lst = ["麻花藤", "王剑林林", "李李嘉诚", "王富贵"] 
    print(lst)
    lst.pop()
    
    deleted = lst.pop()
    print('被删除的',deleted)
    print(lst)
    
    el = lst.pop(2)  # 删除下标位2的元素
    print(el)        # 被删除的元素
    print(lst)
    

    remove 通过元素删除

    lst = ["麻花藤", "王剑林", "李嘉诚", "王富贵"]
    lst.remove('王剑林')
    print(lst)
    
    结果:
    ['麻花藤', '李嘉诚', '王富贵']
    
    lst.remove('哈哈')   # 删除不存在的元素
    结果:
    Traceback (most recent call last):
      File "D:/python_object/path2/test.py", line 1115, in <module>
        lst.remove('哈哈')   # 删除不存在的元素
    ValueError: list.remove(x): x not in list
    

    clear 清空

    lst = ["麻花藤", "王剑林", "李嘉诚", "王富贵"]
    lst.clear()
    print(lst)
    
    结果:
    []
    

    练习

    写代码,有如下列表,按照要求实现每一个功能
    li = ["alex", "WuSir", "ritian", "barry", "wenzhou"]
    请删除列表中的元素"ritian",并输出添加后的列表
    请删除列表中的第2个元素,并输出删除的元素和删除元素后的列表
    请删除列表中的第2至4个元素,并输出删除元素后的列表
    

    1.3.3 修改

    索引切片修改

    # 修改 
    lst = ["太白", "太黑", "五色", "银王", "⽇天"] 
    lst[1] = "太污"   # 把1号元素修改成太污 print(lst) 
    lst[1:4:3] = ["麻花藤", "哇靠"]     # 切片修改也OK. 如果步长不是1, 要注意元素的数 
    print(lst) 
    lst[1:4] = ["我是哪个村的村长王富贵"]  # 如果切片没有步长或者步长是1. 则不用关心个数 
    print(lst)
    

    1.3.4 查询

    列表是一个可迭代对象,所以可以进行for循环
    
    lst = ["麻花藤", "王剑林", "李嘉诚", "王富贵"]
    
    for i in lst:
        print(i)
    
    结果:
    麻花藤
    王剑林
    李嘉诚
    王富贵
    
    

    练习

    li = ["alex", "WuSir", "ritian", "barry", "wenzhou"]
    将列表li中第三个元素修改成'taibai'
    将列表li中第四个元素修改成'女神'
    将列表li中前三个元素修改成'alex1,alex2,alex3'
    
    

    1.4 列表的嵌套

    注意:采用降维操作,一层一层的看就好

    lst = [1,'太白','wusir',['麻花疼',['可口可乐'],'王健林']]
    
    # 找到wusir
    print(lst[2])
    
    # 找到太白和wusir
    print(lst[1:3])
    
    # 找到太白的白字
    print(lst[1][1])
    
    # 将wusir拿到,然后首字母大写 在扔回去
    
    s = lst[2]
    s = s.capitalize()
    lst[2] = s
    print(lst)
    
    # 简写
    lst[2] = lst[2].capitalize()
    print(lst)
    
    # 把太白换成太黑
    lst[1] = lst[1].replace('白','黑')
    
    # 把麻花疼换成麻花不疼
    lst[3][0] = lst[3][0].replace('疼','不疼')
    print(lst)
    
    # 在可口可乐后边添加一个雪碧
    lst[3][1].append('雪碧')
    print(lst)
    

    练习

    写代码,有如下列表,按照要求实现每一个功能。
    lis = [2, 3, "k", ["qwe", 20, ["k1", ["tt", 3, "1"]], 89], "ab", "adv"]
    将列表lis中的"tt"变成大写(用两种方式)。
    将列表中的数字3变成字符串"100"(用两种方式)。
    将列表中的字符串"1"变成数字101(用两种方式)。
    

    这个知识点用在什么地方:

    你需要存储大量的数据,且需要这些数据有序的时候。制定一些特殊的数据群体:按顺序,按规则,自定制设计数据

    二.元祖

    1.对于容器型数据类型list,无论谁都可以对其增删改查,那么有一些重要的数据放在list中是不安全的,所以需要一种容器类的数据类型存放重要的数据,创建之初只能查看而不能增删改,这种数据类型就是元祖。

    元祖:俗称不可变的列表,又被成为只读列表,元祖也是python的基本数据类型之一,

    用小括号括起来,里面可以放任何数据类型的数据,查询可以,循环也可以,切片也可以.但就是不能改.在python中关键字是tuple

    tu = ('我','怎么','这么','可爱')
    
    tu1 = tu[0]  # 记性下标
    print(tu1)
    
    for i in tu:
        print(i)  # 进行for循环
    
    tu2 = tu[0:3]
    print(tu2)  # 进行切片
    
    结果:
    Traceback (most recent call last):
      File "D:/python_object/path2/test.py", line 1286, in <module>
        tu[0] = '你'
    NameError: name 'tu' is not defined
    

    关于不可变, 注意: 这里元组的不可变的意思是子元素不可变. 而子元素内部的子元素是可以变, 这取决于子元素是否是可变对象.

    元组中如果只有一个元素. 一定要添加一个逗号, 否则就不是元组

    tu = ('meet')
    print(type(tu))  #type是查看数据类型
    
    结果:
    <class:str>
    
    tu = ('meet',)
    print(type(tu))  #type是查看数据类型
    
    结果:
    <class:tuple>
    

    这个知识点如何使用

    1.可遍历

    2.可切片

    3.有len,count,index方法

    2.1 元祖嵌套

    tu = ('今天姐姐不在家','姐夫和小姨子在客厅聊天',('姐夫问小姨子税后多少钱','小姨子低声说道说和姐夫还提钱'))
    tu1 = tu[0]
    tu2 = tu[1]
    tu3 = tu[2][0]
    tu4 = tu[2][1]
    
    print(tu1)
    print(tu2)
    print(tu3)
    print(tu4)
    结果:
    今天姐姐不在家
    姐夫和小姨子在客厅聊天
    姐夫问小姨子税后多少钱
    小姨子低声说道说和姐夫还提钱
    

    在哪里使用

    就是将一些非常重要的不可让人改动的数据放在元祖中,只供查看。后期你们写项目的时候会有配置文件,配置文件中的不想让人修改的单个变量使用常量,如果是多个不想让人修改的就是用元组来存储

    三.range

    翻译过来就是范围,那我们我来先看下.

    range(0,5,1)
    
    参数第一个是范围的起始位置
    参数第二个是范围的结束位置
    参数第三个是步长
    print(range(0,5))
    # 结果:
    range(0, 5)  #一个范围
    # 我们可以通过list方法来转换这个范围来查看一下
    l = list(range(0,5))
    print(l)
    
    # 结果:
    [0, 1, 2, 3, 4]
    l = list(range(0,5,2))
    print(l)
    # 结果:
    [0, 2, 4]   # 这个结果就会发现和我之前用步长获取的内容是相似的,是的他就是步长
    

    练习  

    利用for循环和range打印出下面列表的索引。
    
    li = ["alex", "WuSir", "ritian", "barry", "wenzhou"]
    
    利用for循环和range找出100以内所有的偶数并将这些偶数插入到一个新列表中
    
    利用for循环和range 找出50以内能被3整除的数,并将这些数插入到一个新列表中
    
    利用for循环和range从100~1,倒序打印
    
    利用for循环和range,将1-30的数字一次添加到一个列表中,并循环这个列表,将能被3整除的数改成*。
    

    四.字典

    一.字典

    列表可以存储大量的数据类型,但是只能按照顺序存储,数据与数据之间关联性不强。

    所以咱们需要引入一种容器型的数据类型,解决上面的问题,这就需要dict字典。

    字典(dict)是python中唯⼀的⼀个映射类型.他是以{ }括起来的键值对组成.

    在dict中key是 唯⼀的.在保存的时候, 根据key来计算出⼀个内存地址. 然后将key-value保存在这个地址中.

    这种算法被称为hash算法, 所以, 切记, 在dict中存储的key-value中的key必须是可hash的

    可以改变的都是不可哈希的, 那么可哈希就意味着不可变. 这个是为了能准确的计算内存地址⽽规定的.

    已知的可哈希(不可变)的数据类型: int, str, tuple, bool 不可哈希(可变)的数据类型: list, dict, set

    语法:{'key1':1,'key2':2}
    

    注意: key必须是不可变(可哈希)的. value没有要求.可以保存任意类型的数据

    # 合法
    dic = {123: 456, True: 999, "id": 1, "name": 'sylar', "age": 18, "stu": ['帅
    哥', '美⼥'], (1, 2, 3): '麻花藤'}
    print(dic[123])
    print(dic[True])
    print(dic['id'])
    print(dic['stu'])
    print(dic[(1, 2, 3)])
    
    # 不合法
    # dic = {[1, 2, 3]: '周杰伦'} # list是可变的. 不能作为key
    # dic = {{1: 2}: "哈哈哈"} # dict是可变的. 不能作为key
    dic = {{1, 2, 3}: '呵呵呵'} # set是可变的, 不能作为key
    

    注意:dict保存的数据不是按照我们添加进去的顺序保存的. 是按照hash表的顺序保存的. ⽽hash表 不是连续的. 所以不能进⾏切片⼯作. 它只能通过key来获取dict中的数据

    1.1 字典增删改查

    1.1.1 增

    dic = {}
    
    dic['name'] = '汪峰'
    dic['age'] = 18
    print(dic)
    
    结果:
    {'name': '汪峰', 'age': 18}
    # 如果dict中没有出现这个key,就会将key-value组合添加到这个字典中
    
    # 如果dict中没有出现过这个key-value. 可以通过setdefault设置默认值
    s1 = dic.setdefault('王菲')
    print(s1)
    print(dic)
    结果:
    None    
    # 返回的是添加进去的值
    {'王菲': None}  
    # 我们使用setdefault这个方法 里边放的这个内容是我们字典的健,这样我们添加出来的结果
    就是值是一个None
    
    dic.setdefault('王菲',歌手)    
    # 这样就是不会进行添加操作了,因为王菲在dic这个字典中存在
    # 总结: 当setdefault中第一个参数存在这个字典中就就不进行添加操作,否则就添加
    
    dic1 = {}
    s2 = dic1.setdefault('王菲','歌手')
    print(s2)
    print(dic1)
    结果: 
    歌手
    {'王菲': '歌手'}
    

    1.1.2删

    dic = {'剑圣':'易','哈啥给':'剑豪','大宝剑':'盖伦'}
    s = dic.pop('哈啥给')   # pop删除有返回值,返回的是被删的值
    print(s)
    
    print(dic)    # 打印删除后的字典
    dic.popitem()  # 随机删除  python3.6是删除最后一个
    print(dic)
    
    dic.clear()  # 清空
    

    1.1.3改

    dic = {'剑圣':'易','哈啥给':'剑豪','大宝剑':'盖伦'}
    dic['哈啥给'] = '剑姬'   # 当哈哈给是字典中的健这样写就是修改对应的值,如果不存在就是添加
    
    print(dic)
    dic.update({'key':'v','哈啥给':'剑姬'})
    
    # 当update中的字典里没有dic中键值对就添加到dic字典中,如果有就修改里边的对应的值
    print(dic)
    

    1.1.4 查

    dic = {'剑圣':'易','哈啥给':'剑豪','大宝剑':'盖伦'}
    s = dic['大宝剑']        #通过健来查看,如果这个健不在这个字典中.就会报错
    print(s)
    
    s1 = dic.get('剑圣')     #通过健来查看,如果这个健不在这个字典中.就会返回None
    print(s1)
    
    s2 = dic.get('剑姬','没有还查你是不是傻')  # 我们可以在get查找的时候自己定义返回的结果
    print(s2)
    

    练习

    dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]}
    请在字典中添加一个键值对,"k4": "v4",输出添加后的字典
    请在修改字典中 "k1" 对应的值为 "alex",输出修改后的字典
    请在k3对应的值中追加一个元素 44,输出修改后的字典
    请在k3对应的值的第 1 个位置插入个元素 18,输出修改后的字典
    

    1.2 字典其他操作

    1.2.1 获取字典所有的键

    key_list = dic.keys()    
    print(key_list)
    
    结果:
    dict_keys(['剑圣', '哈啥给', '大宝剑'])
    # 一个高仿列表,存放的都是字典中的key
    

    1.2.2 获取字典所有的值

    value_list = dic.values()
    print(value_list)
    
    结果:
    dict_values(['易', '剑豪', '盖伦'])
    #一个高仿列表,存放都是字典中的value
    

    1.2.3 获取字典的键值对

    key_value_list = dic.items()
    print(key_value_list)
    结果:
    dict_items([('剑圣', '易'), ('哈啥给', '剑豪'), ('大宝剑', '盖伦')])
    
    # 一个高仿列表,存放是多个元祖,元祖中第一个是字典中的键,第二个是字典中的值
    

    练习

    循环打印字典的值

    循环打印字典的键

    循环打印元祖形式的键值对

    dic = {'剑圣':'易','哈啥给':'剑豪','大宝剑':'盖伦'}
    
    for i in dic:
        print(i)
    
    for i in dic.keys():
        print(i)
    

    循环打印字典中的键

    dic = {'剑圣':'易','哈啥给':'剑豪','大宝剑':'盖伦'}
    for i in dic:
        print(dic[i])
    
    for i in dic.values():   
        print(i)
    

    循环打印字典中的值和值

    dic = {'剑圣':'易','哈啥给':'剑豪','大宝剑':'盖伦'}
    for i in dic.items():
        print(i)
    

    循环打印元祖形式的键值对

    1.3 解构

    a,b = 1,2
    print(a,b)
    结果:
    1 2
    
    a,b = ('你好','世界')
    print(a,b)
    结果:
    你好 世界
    
    a,b = ['你好','大飞哥']
    print(a,b)
    结果:
    你好 世界
    
    a,b = {'汪峰':'北京北京','王菲':'天后'}
    print(a,b)
    结果:
    汪峰 王菲
    

    解构可以将内容分别赋值到变量当中,我们使用解构就能够快速的将值使用

    1.3.1 循环字典获取键和值

    for k,v in dic.items():
        print('这是键',k)
        print('这是值',v)
    
    结果:
    这是键 剑圣
    这是值 易
    这是键 哈啥给
    这是值 剑豪
    这是键 大宝剑
    这是值 盖伦
    

    1.4 字典的嵌套

    dic = {
        'name':'汪峰',
        'age':48,
        'wife':[{'name':'国际章','age':38}],
        'children':['第一个熊孩子','第二个熊孩子']
    }
    

    获取汪峰的妻子名字

    d1 = dic['wife'][0]['name']
    print(d1)
    

    获取汪峰的孩子们

    d2 = dic['children']
    print(d2)
    

    获取汪峰的第一个孩子

    d3 = dic['children'][0]
    print(d3)
    

    练习

    dic1 = {
     'name':['alex',2,3,5],
     'job':'teacher',
     'oldboy':{'alex':['python1','python2',100]}
     }
    1,将name对应的列表追加⼀个元素’wusir’。
    2,将name对应的列表中的alex⾸字⺟⼤写。
    3,oldboy对应的字典加⼀个键值对’⽼男孩’,’linux’。
    4,将oldboy对应的字典中的alex对应的列表中的python2删除
    
    python
  • 相关阅读:
    设置 tableview 的背景颜色,总是有蒙层
    设置 tableview 的背景颜色,总是不生效
    bug: 在使用HMSegmentedControl时,设置selectionIndicatorEdgeInsets对左右边界没有用
    心情烦闷annoying,贴几个图!唉!annoying
    [EffectiveC++]item28:避免返回handles指向对象内部成分
    Memorize and recite an important historical speech
    NCE3
    NCE2
    015 volatile关键字 线程函数的lParam 原子操作和旋转锁.
    015 原子操作 旋转锁
  • 原文地址:https://www.cnblogs.com/bky20061005/p/12145326.html
Copyright © 2020-2023  润新知