• python(列表)


    列表

    序列是 Python 中最基本的数据结构。

    序列中的每个值都有对应的位置值,称之为索引,第一个索引是 0,第二个索引是 1,依此类推。

    Python 有 6 个序列的内置类型,但最常见的是列表和元组。

    列表都可以进行的操作包括索引,切片,加,乘,检查成员。

    此外,Python 已经内置确定序列的长度以及确定最大和最小的元素的方法。

    列表是最常用的 Python 数据类型,它可以作为一个方括号内的逗号分隔值出现。

    列表的数据项不需要具有相同的类型,可以存放任意类型的数据

    创建列表

    list1 = ['Google', 'Runoob', 1997, 2000]
    list2 = [1, 2, 3, 4, 5 ]
    list3 = ["a", "b", "c", "d"]
    list4 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
    list5 = [11, 11.23, True, '23232', ['11', '22']]

    列表索引

    正向索引(索引值从0,1,2......,n-1(n为列表数据的数量))

    list2 = [11, 11.23, True, '23232', ['11', '22'],(5,6)]
    print(list2[0])                                            #list2[0]表示取列表的第一个,即list2[0]=11;list2[1]=11.23;....依次类推
    print(list2[1])
    print(list2[2])
    print(list2[3])

    反向索引(索引值从-1,-2,-3......,n)

    list2 = [11, 11.23, True, '23232', ['11', '22'],(5,6)]
    print(list2[-1])                                       #list2[-1]表示取列表最后一个,即list2[-1]=(5,6);list2[-2]=['11','22'];....依次类推
    print(list2[-2])
    print(list2[-3])
    print(list2[-4])

    使用索引截取列表(切片)

    【start:end】

    start:起始索引

    end:结尾索引(不包含)

    list = [11, 11.23, True, '23232', ['11', '22'],(5,6)]
    print(list[0:2])                                     #list[0:2]表示取出list[0]、list[1]的值,不包括list[2]
    print(list[1:-1])                                    #表示从list[1]=11.23开始,到list[-1]=(5,6)结束(但不包括list[-1],实际是到list[-2]=['11','22']结束)
    print(list[:])                                       #list[:]不填默认从头取到尾,相当于list[0:len(list)]其中len(list)=6
    print(list[1:])                                      #list[1:]表示从下标[1]取到尾
    print(list[:3])                                      #表示从头(list[0])取到3(不包括list[3])
    print(list[-1:-3])                                   #反向取结果会输出为空
    print(list[3:1])

    结论:

    list[start,end]表示:从头下标开始(包含)截取到尾下标(不包含)

    切片补充:

    【start:end:step】

    start:起始索引,从0开始,-1表示结束

    end:结束索引

    step:步长,end-start,步长为正时,从左向右取值。步长为负时,反向取值

    a = [1,2,3,4,5,6,7]
    print(a[1:5:2])           #从a[1]开始到a[5](不包括a[5]);步长为2,即取a[1]、a[3],即【2,4】
    print(a[::-1])            #a[::-1]即a[-1:-len(a)-1:-1];len(a)为7即长度;则可看成a[-1:-8:-1];则从a[-1]=7开始,到a[-8](不包含)即到a[-7]=1;步长为-1,则结果倒序[7,6,5,4,3,2,1]
    print(a[1::-1])           #a[1::-1]即a[1:-8:-1];从a[1]=2开始,到a[-8](不包含)即到a[-7]=1;所以结果输出[2,1]
    print(a[:2:-1])           #a[:2:-1]即a[-1:2:-1];从a[-1]=7开始,到a[2](不包含),即到a[3]=4;则结果为[7,6,5,4]

    说明:

    b = a[i:j]   # 表示复制a[i]到a[j-1],以生成新的list对象
    
    a = [0,1,2,3,4,5,6,7,8,9]
    b = a[1:3]   # [1,2]
    
    # 当i缺省时,默认为0,即 a[:3]相当于 a[0:3]
    # 当j缺省时,默认为len(alist), 即a[1:]相当于a[1:10]
    # 当i,j都缺省时,a[:]就相当于完整复制一份a
    
    b = a[i:j:s]    # 表示:i,j与上面的一样,但s表示步进,缺省为1.
    # 所以a[i:j:1]相当于a[i:j]
    
    # 当s<0时,i缺省时,默认为-1. j缺省时,默认为-len(a)-1
    # 所以a[::-1]相当于 a[-1:-len(a)-1:-1],也就是从最后一个元素到第一个元素复制一遍,即倒序。

    列表增删查改

    append()方法:用于在列表末尾添加一个元素

    li = [11, 22, 33, 44]
    li.append(99)
    li.append(999)
    print(li)

    extend()方法:往列表尾部一次性添加多个元素
    可以添加列表、元组、集合、字典,若为字典,则仅会将键(key)作为元素依次添加至原列表的末尾

    li = [11, 22, 33, 44]
    li.extend([888, 999, 777])
    li.extend('abc')
    print(li)

    insert()方法:用于将指定对象插入列表的指定位置

    li = [11, 22, 33, 44]
    li.insert(2, 'musen')#表示在位置【2】插入一个'musen'字符串
    print(li)

    拓展:insert 和 append 函数;当增加的是列表中的一个元素(子列表),则新增的元素初始只作为原元素的一个镜像,这时候如果修改原元素(子列表)中的一个子元素,则新增元素同样变化,修改新元素中的子元素也是如此

    a=[[0,1],[1,2],[2,3]]           #其中a[0]=[0,1];a[1]=[1,2];a[2]=[2,3];属于嵌套列表
    a.insert(2,a[1])                #在位置2插入一个a[1];得到a=[a[0],a[1],a[2],a[3]];说白了就是把自己的子列表插了进去,相当于搞了个镜像
    a.append(a[3])                  #在末尾加了一个a[3];得到a=[a[0],a[1],a[2],a[3],a[4]];同上
    print (a)                       #此时a=[[0, 1], [1, 2], [1, 2], [2, 3], [2, 3]]
    a[1][1]=0                       #a[1][1]=0实际就是把a=[[0,1],[1,2],[1,2],[2,3],[2,3]];标记的2改为了0
    a[4][1]=4                       #同上
    print(a)                        #a=[[0, 1], [1, 0], [1, 0], [2, 4], [2, 4]];结果之前插入和添加的“镜像”也发生了改变

     如果想只修改其中一个元素(子列表),必须把该子列表完整定义一遍

    a=[[0,1],[1,2],[2,3]]
    a.insert(2,a[1])
    a.append(a[3])
    print (a)
    a[1][1]=0
    a[4][1]=4
    print(a)
    a[1]=[1,1]                     #完整定义
    print(a)

     用id()查看下内存地址

    a=[[0,1],[1,2],[2,3]]
    a.insert(2,a[1])
    print(id(a[1])==id(a[2]))        #Ture,说明a[1]、a[2]的存放地址(内存地址)都是同一个,所以后面修改其中一个的内容,另一个也会跟着变
    print(a)
    
    a.append(a[3])
    print(id(a[3])==id(a[4]))         #Tuer
    print (a)
    
    a[1][1]=0
    print(id(a[1])==id(a[2]))        #Ture
    a[4][1]=4
    print(id(a[3])==id(a[4]))        #Ture
    print(a)
    
    a[1]=[1,1]
    print(id(a[1])==id(a[2]))        #false,重新完整定义后,实质是相当于重新添加了一个对象,地址就改变了
    print(a)

    remove()方法:指定元素进行删除

    li = [11, 22, 33, 44, 55, 66, 77, 88, 99,11,22,33,11,22]
    li.remove(11)                                             #列表有多个11元素,删除时只删除第一个匹配对象(最靠前的那个)
    print(li)

    pop()方法:指定索引进行删除(默认删除最后一个)

    li = [11, 22, 33, 44, 55, 66, 77, 88, 99,11,22,33,11,22]
    res = li.pop(0)#pop方法执行后,会返回删除的数据
    print("删除的元素是:",res)
    print(li)

    clear()方法:清空列表所有元素(调用完会返回删除的数据)

    li = [11, 22, 33, 44, 55, 66, 77, 88, 99,11,22,33,11,22]
    li.clear()
    print(li)

    修改列表元素:直接可通过索引值进行修改

    li = [11, 22, 33, 44, 55]
    li[2] = 333
    print(li)

    查找元素:

    li = [11, 22, 33, 44, 55,11,22,11,11,11]
    # 方式1:索引取值
    res = li[3]
    print(res)
    
    # index:查找元素对应的索引,只会找到第一个
    res = li.index(22)
    print(res)
    
    # count:统计某个元素的个数
    res = li.count(55)
    print(res)

    python表达式                                     结果                                                   说明

    len([1, 2, 3])                                        3                                                        长度
    [1, 2, 3] + [4, 5, 6]                               [1, 2, 3, 4, 5, 6]                                  组合
    ['Hi!'] * 4                                              ['Hi!', 'Hi!', 'Hi!', 'Hi!']                           重复
    3 in [1, 2, 3]                                        True                                                   元素是否存在于列表中
    for x in [1, 2, 3]: print(x, end=" ")        1 2 3                                                   迭代

     

    列表拼接

    li1 = [1,2,3]
    li1 += [4,5,6]
    print(li1)

    python列表的函数:

    len(list)
    列表元素个数


    max(list)
    返回列表元素最大值


    min(list)
    返回列表元素最小值


    list(seq)
    将元组转换为列表

    python列表的方法:

    list.append(obj)
    在列表末尾添加新的对象


    list.count(obj)
    统计某个元素在列表中出现的次数


    list.extend(seq)
    在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)


    list.index(obj)
    从列表中找出某个值第一个匹配项的索引位置


    list.insert(index, obj)
    将对象插入列表


    list.pop([index=-1])
    移除列表中的一个元素(默认最后一个元素),并且返回该元素的值


    list.remove(obj)
    移除列表中某个值的第一个匹配项


    list.reverse()
    反向列表中元素


    list.sort( key=None, reverse=False)
    对原列表进行排序

    升序(从小到大):li2.sort()
    降序(从大到小):li2.sort(reverse=True)

    列表倒序li2.reverse()


    list.clear()
    清空列表


    list.copy()
    复制列表

    补充:

    append() 属于是浅拷贝

    alist = []
    num = [2]
    alist.append( num )
    print(id( num ) == id( alist[0] ))   #从输出结果为ture可知,拷贝后,num和alist[0]的地址是一样的,此时若改变其中一个的值,另一个也会随之改变

    需要使用深拷贝方法

    import copy
    
    alist = []
    num = [2]
    alist.append(copy.deepcopy( num ) )
    print(id( num ) == id( alist[0] ))

    拓展:

    [表达式 for 变量 in 列表]
    或者
    [表达式 for 变量 in 列表 if 条件]
    list1 = [1,2,3,4,5,6,7]
    list2 = [8,9,10,11,12,13,14]
    print([x**2 for x in list1])
    print([i for i in range(5)])
    print([[i for i in range(5)] for i in range(5)])
    print ([x**2 for x in list1 if x>5])
    print (dict([(x,x*10) for x in list1]))
    print ([ (x, y) for x in range(10) if x % 2 if x > 3 for y in range(10) if y > 7 if y != 8 ])
    
    sq=[list1[i]+list2[i] for i in range(len(list1))]
    print(sq)
    print ([x*y for x in [1,2,3] for y in  [1,2,3]])
    
    testList = [1,2,3,4]
    def mul2(x):
        return x*2
    print ([mul2(i) for i in testList])

  • 相关阅读:
    Spring Boot 7:配置文件信息读取
    Spring Boot 6:自定义filter
    Spring AOP:Java动态代理和CGlib
    Spring AOP:概念
    设计模式(二)---策略模式
    设计模式(一)--装饰模式
    java并发编程实战笔记
    剑指offer java -查找旋转数组的最小数字
    读书计划
    协议初学
  • 原文地址:https://www.cnblogs.com/wuyufeng-9-14/p/15508442.html
Copyright © 2020-2023  润新知