Python数据容器之Python列表的用法

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
简介: 这里的数据结构主要描述容器数据类型:列表, 字典, 集合三种容器数据类型, 它们都属于可变数据类型,

这是机器未来的第7篇文章



1. 数据结构概述

这里的数据结构主要描述容器数据类型:列表, 字典, 集合三种容器数据类型, 它们都属于可变数据类型, 前面提到的数值类型和字符串类型、元组, 它们都属于不可变数据类型,不可以修改。

列表是Python容器数据类型,它是整个人工智能体系的容器数据结构底层核心,在它的基础上,扩展出了Numpy——机器学习数据容器,扩展出了Tensor——深度学习数据容器,所以要想学会人工智能,必须理解列表的使用。


2. 列表

列表是容器数据类型,可存储多个元素,且支持不同类型数据,可修改,有序列表,可重复。

举例:

x = [1, 'abc', True, {"name":"Joe"}, 1, 2, ['7', '89']]

x

例子中展现了以下情况:

  • 不同的数据类型共存一个列表的情况:有数值类型、字符串、有列表、字典
  • 列表包含其他容器类型:字典{"name":"Joe"}和列表['7', '89']
  • 列表展现了重复的数据,列表中存在2个1

2.1 定义列表

定义列表有2种方法:list()函数和[]列表运算符。

2.1.1 list()函数

首先看一下list()函数的描述:

list?

从输出的描述信息中可知,list仅支持1个参数:

  • 可为空,为空时则创建一个空列表

x1 = list()

print(x1, type(x1))

  • 不为空时,参数必须是可迭代类型
  • 什么是可迭代对象呢?举个简单的例子,能够在for循环中遍历使用的都是可迭代类型,具体的可迭类型有字符串、列表、元组、字典。

x0 = list()                         # 无参数,空列表

print(x0, type(x0))

x1 = list("name")                   # 用字符串初始化列表

print(x1, type(x1))

x2 = list([1, 2, 'a', 'b', 'c'])    # 用列表初始化列表      

print(x2, type(x2))

x3 = list((1, 2, 3, 4))             # 用元组初始化列表

print(x3, type(x3))

d1 = {"name":"zsm", "age":18, "sex":"male"}

x4 = list(d1.keys())                  # 用字典初始化列表:对于key和value需要分别处理

x5 = list(d1.values())

print(x4, type(x4), x5, type(x5))

2.1.2 []列表运算符

x1 = []                 # 空列表

print(x1, type(x1))

x2 = [1, 2, 3, 4]       # 有元素的列表

print(x2, type(x2))

2.2 列表常用方法

x = [1, 2, 3, 4, 5]

dir(x)

['add',</br> 'class',</br> 'contains',</br> 'delattr',</br> 'delitem',</br> 'dir',</br> 'doc',</br> 'eq',</br> 'format',</br> 'ge',</br> 'getattribute',</br> 'getitem',</br> 'gt',</br> 'hash',</br> 'iadd',</br> 'imul',</br> 'init',</br> 'init_subclass',</br> 'iter',</br> 'le',</br> 'len',</br> 'lt',</br> 'mul',</br> 'ne',</br> 'new',</br> 'reduce',</br> 'reduce_ex',</br> 'repr',</br> 'reversed',</br> 'rmul',</br> 'setattr',</br> 'setitem',</br> 'sizeof',</br> 'str',</br> 'subclasshook',</br> 'append',</br> 'clear',</br> 'copy',</br> 'count',</br> 'extend',</br> 'index',</br> 'insert',</br> 'pop',</br> 'remove',</br> 'reverse',</br> 'sort']

使用dir函数列出列表可支持的方法和属性,从输出可知方法有'append', 'clear', 'copy', 'count', 'extend', 'index', 'insert', 'pop', 'remove', 'reverse', 'sort'。

2.2.1 添加

  • li.append(x):向列表尾部添加一个元素

x = [1, 2, 3, 4, 'abc', True]

x.append(7)         # 在末尾插入一个对象        

x

[1, 2, 3, 4, 'abc', True, 7]

  • li.insert(index,object):向列表的指定位置插入一个元素

x.insert(2, 'boy')  # 在索引为2的位置插入对象boy

x

[1, 2, 'boy', 3, 4, 'abc', True, 7]

  • li.extend(li2):合并,将参数列表中的元素合并到原列表中

x2 = ['banana', 'apple']

x.extend(x2)        # 注意:是将列表x2中的元素合并到x中,不是将x2整体合并到x中

x

[1, 2, 'boy', 3, 4, 'abc', True, 7, 'banana', 'apple']

2.2.2 删除

  • li.pop(index):删除指定位置的一个元素

y = x.pop(4)        # 取出列表中的元素4,取出后元素不再存于x中        

print(x, y)

[1, 2, 'boy', 3, 'abc', True, 7, 'banana', 'apple'] 4

  • li.remove(object):删除指定内容的一个元素,object是要删除的元素,只能删除第一个

x.append(2)         # 插入一个新的对象2到列表中

print(x)

x.remove(2)         # 删除一个值为2的对象,且仅删除第一个

print(x)

[1, 2, 'boy', 3, 'abc', True, 7, 'banana', 'apple', 2][1, 'boy', 3, 'abc', True, 7, 'banana', 'apple', 2]

  • li.clear():清空列表中的所有元素

x.clear()           # 清除对象

x

[]

2.2.3 序列

  • li.reverse():将列表反序,等同于[::-1]

x = [1, 2, 3, 4, 'abc', True]

print(x)

x.reverse()         # 逆序

print(x)

[1, 2, 3, 4, 'abc', True][True, 'abc', 4, 3, 2, 1]

  • li.sort():对列表排序,可按照升序或降序排列

x = [1, 2, 3, 7, 8,3, 2,2]

x.sort()

print(x)

[1, 2, 2, 2, 3, 3, 7, 8]

2.2.4 其它

  • li.count(object):对列表中的某个元素进行计数

x = [1, 2, 3, 7, 8,3, 2,2]

x.count(2)

3

  • li.index(object):获得列表中元素的索引,返回第一个匹配的索引

x = [1, 2, 3, 7, 8,3, 2,2]

x.index(2)

1

2.2.5 修改

列表可以通过索引修改对应的值。

2.3 列表推导式

列表推导式是一个根据条件从原列表快速生成新列表的简写方法,其语法为

[输出值 for 遍历的元素 in 列表变量 if 条件语句]

举例:快速删除列表中的数字3

x = [1, 2, 3, 4, 5, 3, 6, 7]

x = [i for i in x if i!=3]

print(x)

[1, 2, 4, 5, 6, 7]

以上就是python列表的基础语法知识,更加深入的用法会在人工智能的学习过程中学到!

《Python零基础快速入门系列》快速导航:

推荐阅读:

相关文章
|
9天前
|
图形学 Python
SciPy 空间数据2
凸包(Convex Hull)是计算几何中的概念,指包含给定点集的所有凸集的交集。可以通过 `ConvexHull()` 方法创建凸包。示例代码展示了如何使用 `scipy` 库和 `matplotlib` 绘制给定点集的凸包。
19 1
|
10天前
|
JSON 数据格式 索引
Python中序列化/反序列化JSON格式的数据
【11月更文挑战第4天】本文介绍了 Python 中使用 `json` 模块进行序列化和反序列化的操作。序列化是指将 Python 对象(如字典、列表)转换为 JSON 字符串,主要使用 `json.dumps` 方法。示例包括基本的字典和列表序列化,以及自定义类的序列化。反序列化则是将 JSON 字符串转换回 Python 对象,使用 `json.loads` 方法。文中还提供了具体的代码示例,展示了如何处理不同类型的 Python 对象。
|
10天前
|
数据采集 Web App开发 iOS开发
如何使用 Python 语言的正则表达式进行网页数据的爬取?
使用 Python 进行网页数据爬取的步骤包括:1. 安装必要库(requests、re、bs4);2. 发送 HTTP 请求获取网页内容;3. 使用正则表达式提取数据;4. 数据清洗和处理;5. 循环遍历多个页面。通过这些步骤,可以高效地从网页中提取所需信息。
|
9天前
|
索引 Python
SciPy 空间数据1
SciPy 通过 `scipy.spatial` 模块处理空间数据,如判断点是否在边界内、计算最近点等。三角测量是通过测量角度来确定目标距离的方法。多边形的三角测量可将其分解为多个三角形,用于计算面积。Delaunay 三角剖分是一种常用方法,可以对一系列点进行三角剖分。示例代码展示了如何使用 `Delaunay()` 函数创建三角形并绘制。
18 0
|
5天前
|
Kubernetes Cloud Native Docker
云原生时代的容器化实践:Docker和Kubernetes入门
【10月更文挑战第37天】在数字化转型的浪潮中,云原生技术成为企业提升敏捷性和效率的关键。本篇文章将引导读者了解如何利用Docker进行容器化打包及部署,以及Kubernetes集群管理的基础操作,帮助初学者快速入门云原生的世界。通过实际案例分析,我们将深入探讨这些技术在现代IT架构中的应用与影响。
23 2
|
15天前
|
Kubernetes 监控 开发者
掌握容器化:Docker与Kubernetes的最佳实践
【10月更文挑战第26天】本文深入探讨了Docker和Kubernetes的最佳实践,涵盖Dockerfile优化、数据卷管理、网络配置、Pod设计、服务发现与负载均衡、声明式更新等内容。同时介绍了容器化现有应用、自动化部署、监控与日志等开发技巧,以及Docker Compose和Helm等实用工具。旨在帮助开发者提高开发效率和系统稳定性,构建现代、高效、可扩展的应用。
|
11天前
|
关系型数据库 MySQL API
|
4天前
|
缓存 监控 开发者
掌握Docker容器化技术:提升开发效率的利器
在现代软件开发中,Docker容器化技术成为提升开发效率和应用部署灵活性的重要工具。本文介绍Docker的基本概念,并分享Dockerfile最佳实践、容器网络配置、环境变量和秘密管理、容器监控与日志管理、Docker Compose以及CI/CD集成等技巧,帮助开发者更高效地利用Docker。
|
5天前
|
监控 持续交付 Docker
Docker 容器化部署在微服务架构中的应用有哪些?
Docker 容器化部署在微服务架构中的应用有哪些?
|
5天前
|
监控 持续交付 Docker
Docker容器化部署在微服务架构中的应用
Docker容器化部署在微服务架构中的应用