美文网首页
7总 列表

7总 列表

作者: 大黄蜂人工智能 | 来源:发表于2018-10-08 19:50 被阅读0次

    1.认识列表(list):

    1.什么是列表

    是python中的容器类的数据类型,可以用来存储多个数据。可变的,有序的。

    • 可变指的是列表中的元素的值和位置以及列表的长度可变 --->决定列表可以进行增删改

    • 有序 --->决定可以通过下标来获取元素

    2.字面量:

    [元素1, 元素2, 元素3....]
    [] ---> 空列表

    列表中的元素可以是任何类型的数据 -->包括整数、浮点数、布尔、字符串、列表、字典、元祖、集合、函数、类的对象等

    list1 = [23, 1.87, 'abc'] # 声明一个变量list1,给它赋了一个列表。列表有三个元素

    声明一个列表,列表中有三个元素,分别是[1,2], 'abc', False

    list2 = [
        [1,2],
        'abc',
        False
    ]
    
    list3 = [
        {'a': 10},
        {'abc': True}
    ]
    print(type(list3))  #<class 'list'>
    

    <class 'list'>

    注意:变量也可以作为列表的元素

    name = '路飞'
    names = ['小明', '小花', '小红', name]
    print(names)
    

    ['小明', '小花', '小红', '路飞']

    3.获取列表的元素:

    1.获取单个元素

    列表[下标]
    说明:列表一旦确定,列表中的每个元素的下标就确定了。下标的范围0~列表长度-1 / -1~列表长度

    names = ['路飞', '娜美', '佐罗', '山治', '罗宾']
    print(names[0], names[-4])
    

    路飞 娜美
    print(names[20]) # 下标不能越界

    2.获取部分元素(切片) ---> 结果是个列表

    和字符串切片一样。
    列表[起始下标:结束下标] --> 从起始下标开始,获取到结束下标前为止
    列表[起始下标:结束下标:步长]

    print(names[1:3])
    print(names[:4:2])
    print(names[::-1])
    print(names[:])
    

    ['娜美', '佐罗'] ['路飞', '佐罗'] ['罗宾', '山治', '佐罗', '娜美', '路飞'] ['路飞', '娜美', '佐罗', '山治', '罗宾']

    4.元素的增删改:

    films = ['绿巨人', '钢铁侠', '蜘蛛侠', '神奇女校']

    1.增(增加元素)

    a.
    列表.append(元素) ---> 在列表的最后添加一个元素

    films.append('美国队长')
    print(films)
    
    films.append('恐怖游轮')
    print(films)
    

    ['绿巨人', '钢铁侠', '蜘蛛侠', '神奇女校', '美国队长']
    ['绿巨人', '钢铁侠', '蜘蛛侠', '神奇女校', '美国队长', '恐怖游轮']

    b.
    列表.insert(下标,元素) ---> 在指定的下标前去添加指定的元素

    films.insert(1, '双瞳')
    print(films)
    
    films.insert(0, '雷神')
    print(films)
    

    ['绿巨人', '双瞳', '钢铁侠', '蜘蛛侠', '神奇女校', '美国队长', '恐怖游轮']
    ['雷神', '绿巨人', '双瞳', '钢铁侠', '蜘蛛侠', '神奇女校', '美国队长', '恐怖游轮']

    2.删(删除列表中的元素)

    a.
    del 列表[下标] ---> 删除列表中指定位置的元素

    注意:
    del语句是python中用来删除数据的语法,可以删除任何数据
    a = 10
    del a
    print(a)

    heros = ['盖伦', '儿童劫','维克拖', '提姆', '托儿索', '儿童劫']
    del heros[-2]
    print(heros)
    

    ['盖伦', '儿童劫', '维克拖', '提姆', '儿童劫']

    b.
    列表.remove(元素) ---> 删除列表中指定的元素
    注意:如果这个元素在列表中有多个,只删最前面的那一个

    heros.remove('儿童劫')
    print(heros)
    

    ['盖伦', '维克拖', '提姆', '托儿索', '儿童劫']

    c.
    列表.pop() ---> 将列表中的最后一个元素取出
    列表.pop(下标) ---> 将列表中指定下标对应的元素取出

    beauty = ['余婷', '范冰冰', '周迅', '杨颖', '杨幂', '赵丽颖']
    person = beauty.pop()
    print(beauty, person)
    
    person = beauty.pop(1)
    print(beauty, person)
    

    ['余婷', '范冰冰', '周迅', '杨颖', '杨幂'] 赵丽颖
    ['余婷', '周迅', '杨颖', '杨幂'] 范冰冰

    3.改(修改列表中的元素)

    列表[下标] = 新值 ---> 修改指定下标对应的元素

    teachers = ['余婷', '骆昊', '王海飞', '肖世荣']
    teachers[0] = 'YuTing'
    print(teachers)

    5.练习:

    for循环变量列表,拿到的就是列表中的每个元素

    numbers = [12, 34, 56, 45, 90, 89]
    for x in numbers:
        print(x)
    
    for index in range(len(numbers)):
        print(index, numbers[index])
    

    12 34 56 45 90 89 0 12 1 34 2 56 3 45 4 90 5 89

    1.用一个列表,保存一个班5个学生的成绩,去求这个班的学生的总成绩

    scores = [89, 78, 90, 56, 89]
    sum1 = 0
    for score in scores:
        sum1 += score
    
    print(sum1)
    

    402

    2.用一个列表,保存多个人的名字(英文的), 将列表中所有的人的名字首字母大写

    names = ['zhangsan', 'XiaoMing', 'lisi', 'wangwu']
    
    # 方法1:
    # 下标
    index = 0
    for name in names:
        # 取出首字母
        first = name[0]
        # 判断首字母是否是大写
        if first.isupper():
            index += 1
            continue
    
        # 新的名字
        new_name = name.title()
        # 修改名字
        names[index] = new_name
    
        index += 1
    print(names)
    
    
    names = ['zhangsan', 'Hu', 'HaHa', 'XiaoMing', 'lisi', 'wangwu', 'Head']
    # 方法二:
    for index in range(len(names)):
        name = names[index]
        # 如果是小写
        if name[0].islower():
            names[index] = name.title()
    print(names)
    

    3.删除上一个列表中,首字母是H的人的名字

    names = ['Zhangsan','XiaoMing', 'Lisi', 'Wangwu']
    names[:] = ['Zhangsan','HaHa', 'XiaoMing', 'Lisi', 'Wangwu', 'Head']
    
    for name in names[:] 相等于:
    new = names[:]
    for name in new:
    
    
    for name in names[:]:
        if name[0] == 'H':
            names.remove(name)
    print(names)
    

    ['Zhangsan', 'XiaoMing', 'Lisi', 'Wangwu']

    ['zhangsan','HaHa','Hu', 'XiaoMing', 'lisi', 'wangwu', 'Huo']
    index = 0 zhangsan
    index = 1 HaHa ['zhangsan','Hu', 'XiaoMing', 'lisi', 'wangwu', 'Huo']
    index = 1 Hu ['zhangsan', 'XiaoMing', 'lisi', 'wangwu', 'Huo']
    index = 1 XiaoMing
    index = 2 Lisi
    index = 3 wangwu
    index = 4 Huo ['zhangsan', 'XiaoMing', 'lisi', 'wangwu']
    index = 4

    names = ['zhangsan', 'HaHa','Hu', 'XiaoMing', 'lisi', 'wangwu', 'Huo']
    index = 0
    while index < len(names):
        name = names[index]
        if name[0] == 'H':
            del names[index]
            continue
        index += 1
    print(names)
    

    ['zhangsan', 'XiaoMing', 'lisi', 'wangwu']

    用一个列表保存一个班的学生的成绩,删除成绩中不及格的学生

    grade = [12, 78, 98, 78]
    new = grade[:]
    for x in new:
        if x < 60:
            grade.remove(x)
    
    print(grade, new, grade[:])
    

    [78, 98, 78] [12, 78, 98, 78] [78, 98, 78]

    6.列表相关运算:

    1.+

    列表1 + 列表2 ---> 将列表1和列表2中的元素合并,产生一个新的列表

    list1 = [1, 2, 3]
    list2 = ['a', 'b', 'c']
    print(list1 + list2)
    print(list1)
    

    [1, 2, 3, 'a', 'b', 'c']
    [1, 2, 3]

    2.*

    列表*n ---> 将列表中的元素重复n次,产生一个新的列表

    
    print(list1*3)
    

    [1, 2, 3, 1, 2, 3, 1, 2, 3]

    3.比较运算

    • 列表1 == 列表2 ---> 判断两个列表中的元素是否相等
    print([1, 2, 3] == [2, 1, 3])   # False
    print([1, 2, 3] == [1, 2, 3])   # True
    
    • 补充:比较是否相等的两种方式,== 和 is
      一个数据有id、value和type三个元素。
      id --> 地址(数据在内存中存储的地址)
      value --> 数据的值
      type --> 数据的类型
      python中变量存储数据的时候存的时候数据的地址(id),取出来用的值(value)

    == --> 判断的是值是否相等
    is --> 判断的是地址是否相等(面试!)

    list1 = [1, 2, 3]
    list2 = [1, 2, 3]
    list3 = list1
    print(id(list1), id(list2), id(list3))
    
    print(list1 == list2)   # True
    print(list1 is list2)   # False
    print(list1 is list3)   # True
    

    (了解)两个列表比较大小,比较的是每个元素的大小

    print([1, 2, 5] > [10, 2, 3, 4])

    7.列表赋值:

    
    list1 = ['a', 'aa', 'aaa']
    list2 = list1   # 将list1中的数据的id赋给list2
    
    list2.append('aaaa')
    print(list2)
    print(list1)
    

    ['a', 'aa', 'aaa', 'aaaa']
    ['a', 'aa', 'aaa', 'aaaa']

    list3 = list1[:] # 将list1中的数据拷贝一份,存到新的内存区域中,然后将新的地址给list3

    list3.pop(0)
    print(list3)
    print(list1)
    

    ['aa', 'aaa', 'aaaa']
    ['a', 'aa', 'aaa', 'aaaa']

    总结:用一个列表给另外一个列表赋值的时候,要注意如果是直接赋值,
    可能会因为修改其他一个列表的元素而影响另外一个列表。如果不想相互影响,赋值的时候赋切片或者拷贝

    list1 = [1, 2, 3]
    list2 = list1
    list1 = [1, 200, 3]
    list1[1] = 'abc'
    print(list1, list2)
    

    ['aa', 'aaa', 'aaaa']
    ['a', 'aa', 'aaa', 'aaaa']

    8.列表相关的方法:

    1.in 和 not in

    元素n in 列表2 ---> 元素n是否是列表2的元素
    元素n not in 列表2 ---> 元素n是否不是列表2的元素

    print([1, 2, 3] in [1, 2, 3, 4, 5])   # False
    print([1, 2, 3] in [[1, 2, 3], 2, 3, 4])  # True
    
    print('abc' in [1, 2, 3, 'abc'])
    

    2.len()

    len(列表) --> 获取指定列表的长度

    print(len([1, 2, 3, 4, 5]))
    

    5

    3.max()和min()

    max(列表) --> 获取列表中最大的元素
    min(列表) --> 获取列表中最小的元素
    要求:a.列表中的元素类型要一致 b.列表中的元素是支持>操作的

    list1 = [1, 2, 3, 100, 90]
    print('max:',max(list1))
    print('min:', min(list1))
    

    max: 100
    min: 1

    list2 = [lambda a:a, lambda x:x*2]
     print(max(list2))
    

    IndentationError: unexpected indent

    4.list()

    list(数据) ---> 将指定的数据转换成列表
    注意:只有序列可以被转换成列表
    序列:字符,range, 列表,字典,元祖,集合,迭代器

    print(list('abcde'))
    print(list(range(5)))
    # print(list(100))  # TypeError
    

    5.count()

    列表.count(元素) --> 获取指定的元素在列表中的个数

    
    names = ['千与千寻', '龙猫', '哈尔的移动城堡', '风之谷', '千与千寻']
    print(names.count('千与千寻'))
    print(names.count('幽灵公主'))
    

    2
    0

    6.extend()

    列表.extend(序列) --> 将序列中的元素添加到列表中

    names.extend('abc')
    print(names)
    
    names.extend(range(3))
    print(names)
    
    names.extend(['11', '22'])
    print(names)
    

    ['千与千寻', '龙猫', '哈尔的移动城堡', '风之谷', '千与千寻', 'a', 'b', 'c']
    ['千与千寻', '龙猫', '哈尔的移动城堡', '风之谷', '千与千寻', 'a', 'b', 'c', 0, 1, 2]
    ['千与千寻', '龙猫', '哈尔的移动城堡', '风之谷', '千与千寻', 'a', 'b', 'c', 0, 1, 2, '11', '22']

    7.index()

    列表.index(元素) --> 获取指定的元素在列表中的下标
    注意:如果元素在列表中有多个,获取最前面的元素的下标

    names = ['沉默的羔羊', '肖生克的救赎', '阿甘正传', '霸王别姬', '阿甘正传']
    print(names.index('肖生克的救赎'))
    print(names.index('阿甘正传'))
     print(names.index('abc'))  # 如果元素不存在,会报错, ValueError
    

    1
    2

    8.reverse()

    列表.reverse() --> 将列表中的元素倒序

    names.reverse()
    print(names)
    

    ['阿甘正传', '霸王别姬', '阿甘正传', '肖生克的救赎', '沉默的羔羊']

    9.sort() 和 sorted

    • 列表.sort() --> 将列表中的元素升序排序(从小到大)
    • 列表.sort(reverse=True) --> 将列表中的元素降序排序(从大到小)
    • sorted(列表) --> 将列表中的元素升序排序后产生一个新的列表(不会改变原列表)
    • sorted(列表,reverse=True) --> 将列表中的元素降序排序后产生一个新的列表(不会改变原列表)
      要求:a.列表中的元素类型要一致 b.列表中的元素是支持>操作的
    scores = [12, 89, 78, 90, 78, 100]
    scores.sort()
    print(scores)
    
    scores = [12, 89, 78, 90, 78, 100]
    scores.sort(reverse=True)
    print(scores)
    
    scores = [12, 89, 78, 90, 78, 100]
    new_scores = sorted(scores, reverse=True)
    print(new_scores)
    

    [12, 78, 78, 89, 90, 100]
    [100, 90, 89, 78, 78, 12]
    [100, 90, 89, 78, 78, 12]

    10.clear()

    列表.clear() --> 清空列表中的元素

    scores.clear()
    print(scores)
    

    []

    11.copy()

    列表.copy() --> 将列表中的元素复制一份产生一个新的列表,和列表[:]的功能一样

    list1 = [1, 2, 3, 'abc']
    new = list1.copy()
    print(new, id(list1), id(new))
    

    [1, 2, 3, 'abc'] 31860456 31861816

    相关文章

      网友评论

          本文标题:7总 列表

          本文链接:https://www.haomeiwen.com/subject/ueejaftx.html