百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

一学就废|Python基础碎片,列表(List)

liuian 2024-12-28 14:13 40 浏览

列表(数组)是一种常见的数据结构,通常,列表的共性操作包括获取、设置、搜索、过滤和排序。以下是对列表的一些常用的操作方法。

基本操作

我们可以在 Python 中操作列表的方法有很多。在我们开始学习这些通用操作之前,以下片段显示了列表最常见的操作。

a = [1, 2, 3, 4, 5]
# 判断列表中是否含有某元素
2 in a
True
 
 
# 通过正数索引获取值
a[0]
1
 
# 通过负数索引获取值
a[-1]
5
 
# 切片[开始:结束:步长]
a[1:]
[2, 3, 4, 5]
 
a[1:-1]
[2, 3, 4]
 
a[1:-1:2]
[2, 4]
 
# 列表逆向输出
a[::-1]
[5, 4, 3, 2, 1]
 
a[:0:-1]
[5, 4, 3, 2]
 
# 赋值
a[0] = 0
a
[0, 2, 3, 4, 5]
 
# 向列表中添加元素或对象
a.append(6)
a
[0, 2, 3, 4, 5, 6]
 
a.extend([7, 8, 9])
a
[0, 2, 3, 4, 5, 6, 7, 8, 9]
 
# 删除元素值
del a[-1]
a
[0, 2, 3, 4, 5, 6, 7, 8]
 
# 推导式生成列表
b = [x for x in range(3)]
b
[0, 1, 2]
 
# 两个列表合并,不会去重
a + b
[0, 2, 3, 4, 5, 6, 7, 8, 0, 1, 2]

初始化

一般来说,如果列表表达式中的项目是不可变对象,我们可以通过 * 运算符创建一个列表。

a = [None] * 3
a
[None, None, None]
 
a[0] = "foo"
a
['foo', None, None]

然而,如果列表表达式中的项目是可变对象,* 运算符将复制该项目的引用 N 次。为了避免这个陷阱,我们应该使用列表推导来初始化列表。

a = [[]] * 3
b = [[] for _ in range(3)]
 
a[0].append("Hello")
a
[['Hello'], ['Hello'], ['Hello']]
 
b[0].append("Python")
b
[['Python'], [], []]

列表复制

将列表分配给变量是一个常见的陷阱。此赋值不会将列表复制到变量。变量仅引用列表并增加列表的引用计数。

import sys
>>> a = [1, 2, 3]
>>> sys.getrefcount(a)
2
>>> b = a
>>> sys.getrefcount(a)
3
>>> b[2] = 123456  # a[2] = 123456
>>> b
[1, 2, 123456]
>>> a
[1, 2, 123456]

拷贝有两种,第一种叫浅拷贝(非递归拷贝),第二种叫深拷贝(递归拷贝),很多时候我们用浅拷贝的方式拷贝一个列表就足够了,但是如果一个列表是嵌套的,就得用深拷贝。

# 浅拷贝
a = [1, 2]
b = list(a)
b[0] = 123
a
[1, 2]
 
b
[123, 2]
 
a = [[1], [2]]
b = list(a)
b[0][0] = 123
a
[[123], [2]]
 
b
[[123], [2]]
 
# 深拷贝
import copy
a = [[1], [2]]
b = copy.deepcopy(a)
b[0][0] = 123
a
[[1], [2]]
 
b
[[123], [2]]

列表推导式

[x for x in range(10)]
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
 
[(lambda x: x**2)(i) for i in range(10)]
[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
 
[x for x in range(10) if x > 5]
[6, 7, 8, 9]
 
[x if x > 5 else 0 for x in range(10)]
[0, 0, 0, 0, 0, 0, 6, 7, 8, 9]
 
[x + 1 if x < 5 else x + 2 if x > 5 else x + 5 for x in range(10)]
[1, 2, 3, 4, 5, 10, 8, 9, 10, 11]
 
[(x, y) for x in range(3) for y in range(2)]
[(0, 0), (0, 1), (1, 0), (1, 1), (2, 0), (2, 1)]

列表拆包

有时,我们想将列表解压缩为变量,以使我们的代码变得更具可读性。在这种情况下,我们将 N 个元素分配给 N 个变量,如下例所示。

arr = [1, 2, 3]
a, b, c = arr
a, b, c
(1, 2, 3)

使用枚举

enumerate 是一个内置函数。它帮助我们同时获取索引(或计数)和元素,而无需使用 range(len(list))的写法。

for i, v in enumerate(range(3)):
    print(i, v)
 
0 0
1 1
2 2
 
for i, v in enumerate(range(3), 1): # start = 1
    print(i, v)
 
1 0
2 1
3 2

zip函数

zip 使我们能够一次遍历多个列表中包含的项目。每当其中一个列表用尽时,迭代就会停止。结果,迭代的长度与最短列表相同。如果不希望这种行为,我们可以使用 itertools。zip_longest 在 Python 3 或 itertools。izip_longest 在 Python 2 中。

a = [1, 2, 3]
b = [4, 5, 6]
list(zip(a, b))
[(1, 4), (2, 5), (3, 6)]
 
c = [1]
list(zip(a, b, c))
[(1, 4, 1)]
 
from itertools import zip_longest
list(zip_longest(a, b, c))
[(1, 4, 1), (2, 5, None), (3, 6, None)]

filter函数

filter 是一个内置函数,帮助我们删除不必要的元素。在 Python 2 中,filter 返回一个列表。但是,在 Python 3 中,filter 返回一个可迭代对象。请注意,列表推导或生成器表达式提供了一种更简洁的方法来过滤列表中的元素。

[x for x in range(5) if x > 1]
[2, 3, 4]
 
l = ['1', '2', 3, 'Hello', 4]
f = lambda x: isinstance(x, int)
filter(f, l)
<filter object at 0x10bee2198>
 
list(filter(f, l))
[3, 4]
 
list((i for i in l if f(i)))
[3, 4]

排序

Python list 提供了一个内置的 list. sort 方法,可以在不使用额外内存的情况下对列表进行就地排序。此外,list.sort 的返回值为无,以避免与 sorted 混淆,该函数只能用于 list。

l = [5, 4, 3, 2, 1]
l.sort()
l
[1, 2, 3, 4, 5]
 
# 倒序
l.sort(reverse=True)
l
[5, 4, 3, 2, 1]

sorted 函数不会就地修改任何可迭代对象。相反,它返回一个新的排序列表。如果某些列表的元素是只读的或不可变的,使用 sorted 比 list. sort 更安全。此外,list.sorted 和 sorted 的另一个区别是 sorted 接受任何可迭代对象。

l = [5, 4, 3, 2, 1]
new = sorted(l)
new
[1, 2, 3, 4, 5]
 
l
[5, 4, 3, 2, 1]
 
d = {3: 'andy', 2: 'david', 1: 'amy'}
sorted(d)  # sort iterable
[1, 2, 3]

要对元素为元组的列表进行排序,使用 operator. itemgetter 很有帮助,因为它为排序的键参数分配了一个键函数。请注意,键应该是可比较的;否则,它将引发 TypeError。

from operator import itemgetter
l = [('andy', 10), ('david', 8), ('amy', 3)]
l.sort(key=itemgetter(1))
l
[('amy', 3), ('david', 8), ('andy', 10)]

operator. itemgetter 很有用,因为该函数返回一个 getter 方法,该方法可以用方法__getitem__应用于其他对象。例如,由于所有元素都__getitem__,因此可以使用 operator.itemgetter 对包含其元素的列表进行排序。

rom pprint import pprint
from operator import itemgetter
l = [
    {'name': 'andy', 'age': 10},
    {'name': 'david', 'age': 8},
    {'name': 'amy', 'age': 3},
]
l.sort(key=itemgetter('age'))
 
pprint(l)
[{'age': 3, 'name': 'amy'},
 {'age': 8, 'name': 'david'},
 {'age': 10, 'name': 'andy'}]

相关推荐

GANs为何引爆机器学习?这篇基于TensorFlow的实例教程为你解惑!

「机器人圈导览」:生成对抗网络无疑是机器学习领域近三年来最火爆的研究领域,相关论文层出不求,各种领域的应用层出不穷。那么,GAN到底如何实践?本文编译自Medium,该文作者以一朵玫瑰花为例,详细阐...

高丽大学等机构联合发布StarGAN:可自定义表情和面部特征

原文来源:arXiv、GitHub作者:YunjeyChoi、MinjeChoi、MunyoungKim、Jung-WooHa、SungKim、JaegulChoo「雷克世界」编译:嗯~...

TensorFlow和PyTorch相继发布最新版,有何变化

原文来源:GitHub「机器人圈」编译:嗯~阿童木呀、多啦A亮Tensorflow主要特征和改进在Tensorflow库中添加封装评估量。所添加的评估量列表如下:1.深度神经网络分类器(DNNCl...

「2022 年」崔庆才 Python3 爬虫教程 - 深度学习识别滑动验证码缺口

上一节我们使用OpenCV识别了图形验证码躯壳欧。这时候就有朋友可能会说了,现在深度学习不是对图像识别很准吗?那深度学习可以用在识别滑动验证码缺口位置吗?当然也是可以的,本节我们就来了解下使用深度...

20K star!搞定 LLM 微调的开源利器

LLM(大语言模型)微调一直都是老大难问题,不仅因为微调需要大量的计算资源,而且微调的方法也很多,要去尝试每种方法的效果,需要安装大量的第三方库和依赖,甚至要接入一些框架,可能在还没开始微调就已经因为...

大模型DeepSeek本地部署后如何进行自定义调整?

1.理解模型架构a)查看深度求索官方文档或提供的源代码文件,了解模型的结构、输入输出格式以及支持的功能。模型是否为预训练权重?如果是,可以在预训练的基础上进行微调(Fine-tuning)。是否需要...

因配置不当,约5000个AI模型与数据集在公网暴露

除了可访问机器学习模型外,暴露的数据还可能包括训练数据集、超参数,甚至是用于构建模型的原始数据。前情回顾·人工智能安全动态向ChatGPT植入恶意“长期记忆”,持续窃取用户输入数据多模态大语言模型的致...

基于pytorch的深度学习人员重识别

基于pytorch的深度学习人员重识别Torchreid是一个库。基于pytorch的深度学习人员重识别。特点:支持多GPU训练支持图像的人员重识别与视频的人员重识别端到端的训练与评估简单的re...

DeepSeek本地部署:轻松训练你的AI模型

引言:为什么选择本地部署?在AI技术飞速发展的今天,越来越多的企业和个人希望将AI技术应用于实际场景中。然而,对于一些对数据隐私和计算资源有特殊需求的用户来说,云端部署可能并不是最佳选择。此时,本地部...

谷歌今天又开源了,这次是Sketch-RNN

前不久,谷歌公布了一项最新技术,可以教机器画画。今天,谷歌开源了代码。在我们研究其代码之前,首先先按要求设置Magenta环境。(https://github.com/tensorflow/magen...

Tensorflow 使用预训练模型训练的完整流程

前面已经介绍了深度学习框架Tensorflow的图像的标注和训练数据的准备工作,本文介绍一下使用预训练模型完成训练并导出训练的模型。1.选择预训练模型1.1下载预训练模型首先需要在Tensorf...

30天大模型调优学习计划(30分钟训练大模型)

30天大模型调优学习计划,结合Unsloth和Lora进行大模型微调,掌握大模型基础知识和调优方法,熟练应用。第1周:基础入门目标:了解大模型基础并熟悉Unsloth等工具的基本使用。Day1:大模...

python爬取喜马拉雅音频,json参数解析

一.抓包分析json,获取加密方式1.抓包获取音频界面f12打开抓包工具,播放一个(非vip)视频,点击“媒体”单击打开可以复制URL,发现就是我们要的音频。复制“CKwRIJEEXn-cABa0Tg...

五、JSONPath使用(Python)(json数据python)

1.安装方法pipinstalljsonpath2.jsonpath与Xpath下面表格是jsonpath语法与Xpath的完整概述和比较。Xpathjsonpath概述/$根节点.@当前节点...

Python网络爬虫的时候json=就是让你少写个json.dumps()

大家好,我是皮皮。一、前言前几天在Python白银交流群【空翼】问了一个Python网络爬虫的问题,提问截图如下:登录请求地址是这个:二、实现过程这里【甯同学】给了一个提示,如下所示:估计很多小伙伴和...