阿里云Python训练营(day4)


简介

今天学习了条件语句和循环语句两个板块,python用的挺多的,之前没怎么了解过,这都是大家必须掌握的,我就就简单讲讲在python里面的具体用法.(列表与元组都是容器,是一系列的对象。)


一、列表

1.列表的定义及创建

列表是有序集合,没有固定大小,能够保存任意数量任意类型的 Python 对象,语法为 [元素1, 元素2, …, 元素n]。

  • 关键点是中括号和逗号
  • 中括号 把所有元素绑在一起
  • 逗号 将每个元素一一分开

(1).创建列表:

演示代码如下:

x = ['one', 'two', 'three', 'four']
print(x, type(x))
# ['one', 'two', 'three', 'four'] <class 'list'>

(2).用range()和推导式创建列表:

演示代码如下:

x = list(range(1, 11, -2))#-2表示在循环中递减2
print(x)
x = [i ** 2 for i in range(1, 10)]
print(x)
# [10, 8, 6, 4, 2] 
# [1, 4, 9, 16, 25, 36, 49, 64, 81]

注意:
由于list的元素可以是任何对象,因此列表中所保存的是对象的指针。即使保存一个简单的[1,2,3],也有3个指针和3个整数对象。


x = [a] * 4操作中,只是创建4个指向list的引用,所以一旦a改变,x中4个a也会随之改变。

演示代码如下:

x = [[0] * 3] * 4
print(x)
# [[0, 0, 0], [0, 0, 0], [0, 0, 0], [0, 0, 0]]

a = [0] * 3
x = [a] * 4
print(x)
# [[0, 0, 0], [0, 0, 0], [0, 0, 0], [0, 0, 0]]

x[0][0] = 1
print(x)
# [[1, 0, 0], [1, 0, 0], [1, 0, 0], [1, 0, 0]] 

(3).创建一个混合列表:

演示代码如下:

mix = [1, 'lsgo', 3.14, [1, 2, 3]]
print(mix)  
# [1, 'lsgo', 3.14, [1, 2, 3]] 

小贴士:
列表不像元组,列表内容可更改 (mutable),因此附加 (append, extend)、插入 (insert)、删除 (remove, pop) 这些操作都可以用在它身上。


2.向列表中添加元素

  • list.append(obj) 在列表末尾添加新的对象,只接受一个参数,参数可以是任何数据类,被追加的元素在 list 中保持着原结构类型。

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

  • list.insert(index, obj) 在编号 index 位置插入 obj。

演示代码如下:

x = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']
x.append('Thursday')
print(x) 
# ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Thursday']


x = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']
x.extend(['Thursday', 'Sunday'])
print(x)  
# ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Thursday', 'Sunday']


x = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']
x.insert(2, 'Sunday')
print(x)
# ['Monday', 'Tuesday', 'Sunday', 'Wednesday', 'Thursday', 'Friday']

注意:
(1).此元素如果是一个 list,那么这个 list 将作为一个整体进行追加,注意append()和extend()的区别。
(2).严格来说 append 是追加,把一个东西整体添加在列表后,而 extend 是扩展,把一个东西里的所有元素添加在列表后。


3.删除列表中的元素

  • list.remove(obj) 移除列表中某个值的第一个匹配项
  • list.pop([index=-1]) 移除列表中的一个元素(默认最后一个元素),并且返回该元素的值
  • del var1[, var2 ……] 删除单个或多个对象。

演示代码如下:

x = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']
x.remove('Monday')
print(x)  # ['Tuesday', 'Wednesday', 'Thursday', 'Friday']


x = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']
y = x.pop()
print(y)  # Friday

y = x.pop(0)
print(y)  # Monday


x = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']
del x[0:2]#从Monday开始的两个元素
print(x)  # ['Wednesday', 'Thursday', 'Friday']

注意:
(1).remove 和 pop 都可以删除元素,前者是指定具体要删除的元素,后者是指定一个索引。
(2).如果你要从列表中删除一个元素,且不再以任何方式使用它,就使用del语句;如果你要在删除元素后还能继续使用它,就使用方法pop()。


4.获取列表中的元素

  • 通过元素的索引值,从列表获取单个元素,注意,列表索引值是从0开始的。
  • 通过将索引指定为-1,可让Python返回最后一个列表元素,索引 -2 返回倒数第二个列表元素,以此类推。

演示代码如下:

x = ['Monday', 'Tuesday', 'Wednesday', ['Thursday', 'Friday']]
print(x[0], type(x[0]))  # Monday <class 'str'>
print(x[-1], type(x[-1]))  # ['Thursday', 'Friday'] <class 'list'>
print(x[-2], type(x[-2]))  # Wednesday <class 'str'>

切片的通常写法是 start : stop : step

  • 情况 1 - "start :"以 step 为 1 (默认) 从编号 start 往列表尾部切片。
  • 情况 2 - ": stop"以 step 为 1 (默认) 从列表头部往编号 stop 切片。
  • 情况 3 - "start : stop"以 step 为 1 (默认) 从编号 start 往编号 stop 切片。
  • 情况 4 - "start : stop : step"以具体的 step 从编号 start 往编号 stop 切片。注意最后把 step 设为 -1,相当于将列表反向排列。
  • 情况 5 - " : "复制列表中的所有元素(浅拷贝)。

演示代码如下:

x = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']
print(x[3:])  # ['Thursday', 'Friday']
print(x[-3:])  # ['Wednesday', 'Thursday', 'Friday']

week = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']
print(week[:3])  # ['Monday', 'Tuesday', 'Wednesday']
print(week[:-3])  # ['Monday', 'Tuesday']

week = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']
print(week[1:3])  # ['Tuesday', 'Wednesday']
print(week[-3:-1])  # ['Wednesday', 'Thursday']

week = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']
print(week[1:4:2])  # ['Tuesday', 'Thursday']
print(week[:4:2])  # ['Monday', 'Wednesday']
print(week[1::2])  # ['Tuesday', 'Thursday']

eek = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']
print(week[:])  
# ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']

5.列表的常用操作符

  • 等号操作符:==
  • 连接操作符:+
  • 重复操作符: *
  • 成员关系操作符:in、not in

列表拼接有两种方式,用加号和乘号 ,前者首尾拼接,后者复制拼接。

演示代码如下:

list1 = [123, 456]
list2 = list1 * 3
print(list2)  # [123, 456, 123, 456, 123, 456]

6.列表的其他方法

  • list.count(obj) 统计某个元素在列表中出现的次数
  • list.index(x[, start[, end]]) 从列表中找出某个值第一个匹配项的索引位置
  • list.reverse() 反向列表中元素

演示代码如下:

list1 = [123, 456] * 3
num = list1.count(123)
print(num)  # 3


print(list1.index(123))  # 0
print(list1.index(123, 1))  # 2
print(list1.index(123, 3, 7))  # 4



x = [123, 456, 789]
x.reverse()
print(x)  # [789, 456, 123]

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

  • key – 主要是用来进行比较的元素,只有一个参数,具体的函数的参数就是取自于可迭代对象中,指定可迭代对象中的一个元素来进行排序。
  • reverse – 排序规则,reverse = True 降序, reverse = False 升序(默认)。
  • 该方法没有返回值,但是会对列表的对象进行排序。

演示代码如下:

x = [123, 456, 789, 213]
x.sort()
print(x)
# [123, 213, 456, 789]

x.sort(reverse=True)
print(x)
# [789, 456, 213, 123]


二、元组

1.创建和访问一个元组

  • Python 的元组与列表类似,不同之处在于tuple被创建后就不能对其进行修改,类似字符串。
  • 元组使用小括号,列表使用方括号。
  • 元组与列表类似,也用整数来对它进行索引 (indexing) 和切片 (slicing)。

演示代码如下:

t1 = (1, 10.31, 'python')
print(t1)
#(1, 10.31, 'python') 

tuple1 = (1, 2, 3, 4, 5, 6, 7, 8)
print(tuple1[1])  # 2
print(tuple1[5:])  # (6, 7, 8)
print(tuple1[:5])  # (1, 2, 3, 4, 5)

注意:
创建元组可以用小括号 (),也可以什么都不用,为了可读性,建议还是用 ()。
元组中只包含一个元素时,需要在元素后面添加逗号,否则括号会被当作运算符使用。


创建二维元组:

演示代码如下:

a=(2,'zmt',9.45),('zgk','bcj','0')
print(a)
#(2,'zmt',9.45),('zgk','bcj','0')

print(a[0],a[0][1],a[1][0])
#(2,'zmt',9.45),'zmt',zgk

print(a[0][0:2])
#(2,'zmt')

2.修改和添加一个元组

演示代码如下:

t = (1, 2, 3, ['d', 5, 6])
t[3][0]=4
print(t)
#(1, 2, 3, [4, 5, 6])

t=t[2:]+'zmt'+t[:2]
print(t)
#(1, 2,'zmt',3, [4, 5, 6])

小贴士:
元组有不可更改 (immutable) 的性质,因此不能直接给元组的元素赋值,但是只要元组中的元素可更改 (mutable),那么我们可以直接更改其元素,注意这跟赋值其元素不同。


3.元组相关的操作符

  • 等号操作符:==
  • 连接操作符: +
  • 重复操作符 : *
  • 成员关系操作符: in、not in

这个代码就不给大家展示了,前面都有这个.

4.内置方法

元组大小和内容都不可更改,因此只有 count 和 index 两种方法。

演示代码如下:

t = (1, 10.31, 'python')
print(t.count('python'))  #count('python') 是记录在元组 t 中该元素出现几次,显然是 1 次
# 1
print(t.index(10.31))  #index(10.31) 是找到该元素在元组 t 的索引,显然是 1
# 1

5.解压元组

(1). 解压(unpack)一维元组(有几个元素左边括号定义几个变量)

演示代码如下:

t = (1, 10.31, 'python')
(a, b, c) = t
print(a, b, c)
# 1 10.31 python

(2). 解压二维元组(按照元组里的元组结构来定义变量)

演示代码如下:

t = (1, 10.31, ('OK', 'python'))
(a, b, (c, d)) = t
print(a, b, c, d)
# 1 10.31 OK python

(3). 如果你只想要元组其中几个元素,用通配符*,英文叫 wildcard,在计算机语言中代表一个或多个元素。下例就是把多个元素丢给了 rest 变量。

演示代码如下:

t = 1, 2, 3, 4, 5
a, b, *rest, c = t
print(a, b, c)  # 1 2 5
print(rest)  # [3, 4]

猜你喜欢

转载自blog.csdn.net/qq_44250569/article/details/108761032