列表是Python中最常用的数据结构之一,它提供了一种方便和灵活地组织和存储数据的方式。无论是保存一系列数字、字符串、对象或者其他数据类型,列表都可以满足你的需求。
创建一个列表,只要把逗号分隔的不同的数据项使用方括号括起来即可。如下所示:
list1 = ['physics', 'chemistry', 1997, 2000]
list2 = [1, 2, 3, 4, 5 ]
list3 = ["a", "b", "c", "d"]
与字符串的索引一样,列表索引从 0 开始。列表可以进行截取、组合等。
列表中元素的类型的多样性
a_list=['lemon', 100, ['a', 'b', 'c', 'd'], True]#同一个list的类型可以是字符串,整型,布尔型(true和false),以及嵌套的lis
使用下标索引来访问列表中的值,同样你也可以使用方括号的形式截取字符,如下所示:
list1 = ['physics', 'chemistry', 1997, 2000]
list2 = [1, 2, 3, 4, 5, 6, 7]
print("list1[0]: ", list1[0]) # list1[0]: physics
# 嵌套列表
list1 = ['physics', 'chemistry', 1997, 2000,[1,2,3,4,5]]
print("list1[0]: ", list1[4][0]) # list1[0]: 1
print(a[1:3]) #按下标0开始,不包括最右边的3
print(a[1:]) #1以及之后的全部
print(a[:3]) #3之前的但不包括3
print(a[:]) #所有
print(a[::2])#[start:end:step]start和end为空的时候,默认是全选,step为空时默认是1,这个表示的是从索引为0开始,以步长为2来选择元素
print(a[1:3:2])#以索引为1开始,索引3结束,步长为2来选择元素
print(a[::-1])#当step为-1时,将列表进行了逆序排序
print(a[::-2])#将列表进行了逆序排序,步长为2来选择元素
修改列表中的元素需要使用索引表示将指定索引位置的元素进行重新赋值。
list1 = ['physics', 'chemistry', 1997, 2000]
list1[0]= 'maths'
print("list1[0]: ", list1[0]) # list1[0]: maths
移除列表中的元素,可以通过 del 语句,通过索引号指定要删除的元素对象。
list1 = ['physics', 'chemistry', 1997, 2000]
del list1[0]
print("list1[0]: ", list1[0]) # list1[0]: chemistry
print('列表相加:', [1, 2, 3] + [4, 5, 6])# 列表相加: [1, 2, 3, 4, 5, 6]
print('列表相乘:', ['a', 'b']*3) # 列表相乘: ['a', 'b', 'a', 'b', 'a', 'b']
print('判断列表元素是否存在于列表中:', 'a' in ['a', 'b']) # True
print('判断列表元素是否存在于列表中:', 'a' not in['a', 'b']) # Falue
python 迭代列表中元素,主要有三种方式,具体如下:
第一种方法(直接)
list1 = ['physics', 'chemistry', 1997, 2000]
for item in list1:
print(item)
或者
names = ['james', 'michael', 'emma', 'emily']
index = 0 #通过while循环来列出所有元素
while index < len(names):
print(names[index])
index += 1
第二种方法range
借助 range 和 len 内置函数,通过元素索引遍历列表元素;
list1 = ['physics', 'chemistry', 1997, 2000]
for i in range(len(list1)):
print(i, list1[i])
第三种方法enumerate
通过内置枚举函数 enumerate 直接获取遍历的索引和元素;
list1 = ['physics', 'chemistry', 1997, 2000]
for i, item in enumerate(list1):
print(i, item)
列表推导式
列表生成式即List Comprehensions,是Python内置的非常简单却强大的可以用来创建list的生成式,使用列表生成式可以节省很多行代码
语法结构如下:
#普通的生成式
[表达式 for 变量 in 旧列表]
#加条件的生成式
[表达式 for 变量 in 旧列表 if 条件]
#if…else条件的生成式
[表达式 if 条件1 else 条件2 for 变量 in 旧列表]
过滤掉名词字母长度不足4的名字,示例代码如下:
names = ["Tom", "Lily", "Jack", "Steven", "Bod"]
# 在不是用列表生成式的过程
news_names = []
for name in names:
if len(name) > 3:
news_names.append(name)
print(news_names) # ['Lily', 'Jack', 'Steven']
# 使用列表生成式
new_names = [name for name in names if len(name) > 3]
print(new_names) # ['Lily', 'Jack', 'Steven']
将1-100的整数可以被3和5整除的数字组成一个新的列表, 示例代码如下所示:
# 旧方法
number_list = []
for i in range(101):
if i % 3 == 0 and i % 5 == 0:
number_list.append(i)
print(number_list) # [0, 15, 30, 45, 60, 75, 90]
# 列表生成式
new_num_list = [i for i in range(101) if i % 3 == 0 and i % 5 == 0]
print(new_num_list) # [0, 15, 30, 45, 60, 75, 90]
将0到10的奇数和0到5的偶数组成一个不重复的列表,示例代码如下所示:
# 将0到10的奇数和0到5的偶数组成一个不重复的列表
# 旧方法
news_number_list = []
for x in range(10):
if x % 2 != 0:
for y in range(5):
if y % 2 == 0:
news_number_list.append([x, y])
print(news_number_list)
# [[1, 0], [1, 2], [1, 4], [3, 0], [3, 2], [3, 4], [5, 0], [5, 2], [5, 4], [7, 0], [7, 2], [7, 4], [9, 0], [9, 2],[9, 4]]
# 新方法
news_num_list = [[x, y] for x in range(10) if x % 2 != 0 for y in range(6) if y % 2 == 0]
print(news_num_list)
# [[1, 0], [1, 2], [1, 4], [3, 0], [3, 2], [3, 4], [5, 0], [5, 2], [5, 4], [7, 0], [7, 2], [7, 4], [9, 0], [9, 2],[9, 4]]
将列表中的数字大于8000的加200 小于等于8000的加500,示例代码如下:
# 将列表中的数字大于8000的加200 小于等于8000的加500
number = [5000, 10000, 4500, 80000, 12000]
# 旧方法
for i in number:
if i > 8000:
i += 200
else:
i += 500
print(number) # [5500, 10200, 5000, 80200, 12200]
# 新方法
new_number = [i + 200 if i > 8000 else i + 500 for i in number]
print(new_number) # [5500, 10200, 5000, 80200, 12200]
len() 方法返回列表元素个数。
print(len([1, 2, 3])) # 3
append() 方法用于在列表末尾添加新的对象。
food=['egg', 'fish', 'cake', 'tomato']
food.append('ice') #在list的末尾添加元素
print(food)
insert() 函数用于将指定对象插入列表。
food=['egg', 'fish', 'cake', 'tomato']
food.insert(1, 'meat') #在1这个位置添加元素
print(food)
pop() 函数用于移除列表中的一个元素(默认最后一个元素),并且返回该元素的值。
food=['egg', 'fish', 'cake', 'tomato']
food.pop() #删除list末尾的元素
print(food)
food.pop(2) #删除索引2的元素
print(food)
定义 remove() 方法具有指定值的首个元素,如果有重复,删除的是第一次出现的元素,如果元素不存在会报错
list2 = [1, 2, 4, 5, 7, 4]
list2.remove(4)#从列表中找出第一个数值为4的值然后删除,不管第二个
print('remove:', list2)
count()方法返回元素出现次数
fruits = ['apple', 'banana', 'cherry']
number = fruits.count("cherry")
print(number)
定义 extend()方法将列表元素(或任何可迭代的元素)添加到当前列表的末尾
list1 = [1, 3, 3, 4, 5]
list2 = [6, 5, 8, 9]
list1.extend(list2) #在列表1后面添加列表2
print(list1)
定义 index()方法返回该元素最小索引值(找不到元素会报错)
list2 = [1, 2, 4, 5, 7, 4]
print('index:', list2.index(4)) # 从列表中找出第一个数值为4的索引位置,不管第二个
从小到大排序,类型不能混 ,使用的是ASCII值进行排序
list2 = [1, 2, 4, 5, 7, 4]
list2.sort()#对原列表进行排序
print('sort;', list2)
定义reverse() 方法反转元素的排序顺序
fruits = ['apple', 'banana', 'cherry']
fruits.reverse()
print(fruits)
定义 clear()方法清空列表所有元素
list2 = [1, 2, 4, 5, 7, 4]
list2.clear()
print(list2)
定义 copy()方法返回指定列表的副本 ,如果某个元素是引用类型那么复制的就是这个元素的地址
fruits = ['apple', 'banana', 'cherry', 'orange']
c = fruits.copy()
print(c
使用用deepcopy()方法,才是真正的复制了一个全新的列表,包含原列表内部的引用类型
import copy
old = [1,[1,2,3],3]
new = copy.deepcopy(old)
注意: 使用深浅拷贝需要导入copy模块,因为深拷贝要拷贝的元素跟多,所以速度会远不如浅拷贝,在编程的过程中要注意避免造成多余的系统负担;
关于Python基础教程之列表用法就到这了,记得好好学,不然就V博主50吃肯德基。
学好 Python 不论是就业还是做副业赚钱都不错,但要学会 Python 还是要有一个学习规划。最后大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!
CSDN大礼包:《Python入门资料&实战源码&安装工具】免费领取(安全链接,放心点击)
Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
② 路线对应学习视频
还有很多适合0基础入门的学习视频,有了这些视频,轻轻松松上手Python~在这里插入图片描述
③练习题
每节视频课后,都有对应的练习题哦,可以检验学习成果哈哈!
因篇幅有限,仅展示部分资料
当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。
学习Python常用的开发软件都在这里了!每个都有详细的安装教程,保证你可以安装成功哦!
光学理论是没用的,要学会跟着一起敲代码,动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。100+实战案例源码等你来拿!
如果觉得上面的实战案例有点枯燥,可以试试自己用Python编写小游戏,让你的学习过程中增添一点趣味!
我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
而且学会Python以后,还可以在各大兼职平台接单赚钱,各种兼职渠道+兼职注意事项+如何和客户沟通,我都整理成文档了。
这份完整版的Python全套学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费
】