python基础05----常用数据类型之列表/元组的所有操作总结

1,列表

【本章节涵盖:列表的创建,增加,删除,修改,查找,循环嵌套方式,以及排序。元组的操作,和列表的区分注意点】

列表是什么?如果学习过其他语言的小伙伴会很熟悉,不错,它就是数组。

而没学习过编程语言的小伙伴不要急,且容我细细给您道来!大家都知道,保存一个人的名字需要用到一个变量字符串,比如:name=‘张三’,但是如果是一个班级的50个人的名字呢?不要告诉我说,用50个变量来保存,那就偏离了我们编程的本质了。那此时呢,列表就横空出世。

列表的格式:

变量名=[元素,元素2,元素3,元素n ]

# eg:   
 tmp = ['xiaoWang',‘小张’, 65.0]

列表的类型是list,如果查看tmp,使用type(tmp) 然后print打印出来,就能看到是list列表类型的。

列表数据的获取:

列表名[index] ,列表是通过下标来获取数据的,在计算机中是从左到右开始数数,起始从0开始

demo:

    namesList = ['xiaoWang','xiaoZhang','xiaoHua']
    print(namesList[0])
    print(namesList[1])
    print(namesList[2])
结果:

    xiaoWang
    xiaoZhang
    xiaoHua

<1>添加元素("增"append, insert, extend)

列表中存放的数据是可以进行修改的,比如"增"、"删"、"改"、"查"

append
append会把新元素添加到列表末尾

demo:

    #定义变量A,默认有3个元素
    A = ['xiaoWang','xiaoZhang','xiaoHua']

    print("-----添加之前,列表A的数据-----A=%s" % A)

    #提示、并添加元素
    temp = input('请输入要添加的学生姓名:')
    A.append(temp)

    print("-----添加之后,列表A的数据-----A=%s" % A)

insert
insert(index, object) 在指定位置index插入元素object

>>> a = [0, 1, 2]
>>> a.insert(1, 3)
>>> a
[0, 3, 1, 2]


extend
通过extend可以将另一个集合中的元素逐一添加到列表中

>>> a = [1, 2]
>>> b = [3, 4]
>>> a.append(b)
>>> a
[1, 2, [3, 4]]
>>> a.extend(b)
>>> a
[1, 2, [3, 4], 3, 4]

<2>修改元素("改")

我们是通过指定下标来访问列表元素,所以为指定的列表下标赋值就是修改列表中的元素。

    #定义变量A,默认有3个元素
    A = ['xiaoWang','xiaoZhang','xiaoHua']

    print("-----修改之前,列表A的数据-----A=%s" % A)

    #修改元素
    A[1] = 'xiaoLu'

    print("-----修改之后,列表A的数据-----A=%s" % A)

<3>查找元素("查"in, not in, index, count)

所谓的查找,就是看看指定的元素是否存在

in, not in

python中查找的常用方法为:

  • in(存在),如果存在那么结果为true,否则为false
  • not in(不存在),如果不存在那么结果为true,否则false
    #待查找的列表
    nameList = ['xiaoWang','xiaoZhang','xiaoHua']

    #获取用户要查找的名字
    findName = input('请输入要查找的姓名:')

    #查找是否存在
    if findName in nameList:
        print('在字典中找到了相同的名字')
    else:
        print('没有找到')

结果1:(找到)

结果2:(没有找到)

说明:

in的方法只要会用了,那么not in也是同样的用法,只不过not in判断的是不存在

index, count

index和count与字符串中的用法相同

>>> a = ['a', 'b', 'c', 'a', 'b']
>>> a.index('a', 1, 3) # 注意是左闭右开区间
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: 'a' is not in list
>>> a.index('a', 1, 4)
3
>>> a.count('b')
2
>>> a.count('d')
0

<4>删除元素("删"del, pop, remove)

类比现实生活中,如果某位同学调班了,那么就应该把这个条走后的学生的姓名删除掉;在开发中经常会用到删除这种功能。

列表元素的常用删除方法有:

  • del:根据下标进行删除
  • pop:删除最后一个元素
  • remove:根据元素的值进行删除

demo:(del)

    movieName = ['加勒比海盗','骇客帝国','第一滴血','指环王','霍比特人','速度与激情']

    print('------删除之前------movieName=%s' % movieName)

    del movieName[2]

    print('------删除之后------movieName=%s' % movieName)

demo:(pop)

    movieName = ['加勒比海盗','骇客帝国','第一滴血','指环王','霍比特人','速度与激情']

    print('------删除之前------movieName=%s' % movieName)

    movieName.pop()

    print('------删除之后------movieName=%s' % movieName)

demo:(remove)

    movieName = ['加勒比海盗','骇客帝国','第一滴血','指环王','霍比特人','速度与激情']

    print('------删除之前------movieName=%s' % movieName)

    movieName.remove('指环王')

    print('------删除之后------movieName=%s' % movieName)

<5>排序(sort, reverse)

sort方法是将list按特定顺序重新排列,默认为由小到大,参数reverse=True可改为倒序,由大到小。

reverse方法是将list逆置。

>>> a = [1, 4, 2, 3]
>>> a
[1, 4, 2, 3]
>>> a.reverse()  # 逆置,不排序
>>> a
[3, 2, 4, 1]
>>> a.sort()  # 默认从小到大排序
>>> a
[1, 2, 3, 4]
>>> a.sort(reverse=True)  # 从大到小排序
>>> a
[4, 3, 2, 1]

列表的循环遍历

1. 使用while循环

为了更有效率的输出列表的每个数据,可以使用循环来完成

demo:

    namesList = ['xiaoWang','xiaoZhang','xiaoHua']
    length = len(namesList)  # 获取列表长度
    i = 0
    while i<length:
        print(namesList[i])
        i+=1

结果:

    xiaoWang
    xiaoZhang
    xiaoHua

2. 使用for循环

while 循环是一种基本的遍历列表数据的方式,但是最常用也是最简单的方式是使用 for 循环,一般工作中也是基本是使用for循环遍历。

demo:

    namesList = ['xiaoWang','xiaoZhang','xiaoHua']
    for name in namesList:
        print(name)

结果:

    xiaoWang
    xiaoZhang
    xiaoHua

列表的嵌套

1. 列表嵌套

类似while循环的嵌套,列表也是支持嵌套的

一个列表中的元素又是一个列表,那么这就是列表的嵌套,例如二元数组或者多元数组

此处重点掌握怎么操作被嵌套的列表

>>> schoolNames = [
... [1, 2, 3],
... [11, 22, 33],
... [111, 222, 333]
... ]
>>> schoolNames[1][2]  # 获取数字 33
33
>>> schoolNames[1][2] = 'abc'  # 把 33 修改为 'abc'
>>> schoolNames
[[1, 2, 3], [11, 22, 'abc'], [111, 222, 333]]
>>> schoolNames[1][2][2]  # 获取 'abc' 里的字符c
'c'

也就是说,操作嵌套列表,只要把要操作元素的下标当作变量名来使用即可。

小案例如下:

import random
# 应用 案例
#一个学校,有3个办公室,现在有8位老师等待工位的分配,请编写程序,完成随机的分配
# 定义一个列表用来保存3个办公室
offices = [[],[],[]]

# 定义一个列表用来存储8位老师的名字
names = ['A','B','C','D','E','F','G','H']

for name in names:
    index = random.randint(0,2)    
    offices[index].append(name)

i = 1
for tempNames in offices:
    print('办公室%d的人数为:%d'%(i,len(tempNames)))
    i+=1
    for name in tempNames:
        print("%s"%name,end='')
    print("\n")
    print("-"*20)

代码效果可以直接拷贝运行。

2,元组

此处为什么把元组和列表放到同一个文章里讲解呢?原因就是元组其实就是一个可变的列表。只要掌握了列表,那么元组也就是掌握了。说白了,元组的就是一个不可改变的列表

Python的元组与列表类似,不同之处在于元组的元素不能修改。元组使用小括号,列表使用方括号。

>>> aTuple = ('et',77,99.9)
>>> aTuple
('et',77,99.9)

访问元组 和 列表的访问方式相同

修改元组

说明: python中不允许修改元组的数据,包括不能删除其中的元素。

count, index查找

index和count与字符串和列表中的用法相同

>>> a = ('a', 'b', 'c', 'a', 'b')
>>> a.index('a', 1, 3) # 注意是左闭右开区间
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: tuple.index(x): x not in tuple
>>> a.index('a', 1, 4)
3
>>> a.count('b')
2
>>> a.count('d')
0

定义只有一个数据的元组

定义只有一个元素的元组,需要在唯一的元素后写一个逗号

>>> a = (11)
>>> a
11
>>> type(a)
int
>>> a = (11,)  # 只有一个元素的元组,必须要在元素后写一个逗号
>>> a
(11,)
>>> type(a)
tuple

元组的应用一般是在向购买过的历史订单啊等类似的这种一旦产生就永远不可更改的数据使用场景中。

猜你喜欢

转载自blog.csdn.net/qq_36622490/article/details/86521901