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

「Python系列」 Python 数据结构之数组

wxin55 2025-05-08 07:10 1 浏览 0 评论


在大多数编程语言中,数组都是一个基础而又普遍的数据结构。在很多算法中都有广泛的应用。

在本文中,我们将了解鲜为人知的Python数组实现,该实现仅使用Python标准库中包含的核心语言功能。

我们将看到每种方法的优点和缺点,以便我们可以决定哪种实现最适合我们的用例。但是在开始之前,让我们先介绍一些基础知识。

数组如何工作,它们的作用是什么?

数组由固定大小的数据记录组成,这些数据记录允许每个元素根据其索引进行有效定位。

在性能方面,给定元素的索引,查找数组中包含的元素非常快。在这种情况下,适当的数组实现可确保O(1)的访问时间恒定。

Python在标准库中包含具有不同特征的多个类似数组的数据结构。让我们看看它们。

array.array —基本类型数组

Python的数组模块可以节省空间地存储基本的C样式数据类型,例如字节,32位整数,浮点数等。

使用array.array类创建的数组是可变的,并且行为类似于列表,除了一个重要的区别—它们是“类型化数组”,被约束为单个数据类型。

由于此约束,具有许多元素的array.array对象比列表和元组更节省空间。存储在它们中的元素是紧密包装的,如果我们需要存储许多相同类型的元素,这将很有用。

此外,数组支持许多与常规列表相同的方法,并且我们可以将它们用作“直接替换”,而无需对应用程序代码进行其他更改。

>>> import array
>>> arr = array.array('i', (22, 30, 10, 6))
>>> arr[1]
30
# Arrays are mutable
arr[1] = 25
>>> arr
array('i', [22, 25, 10, 6])
>>> arr.append(27)
>>> arr
array('i', [22, 25, 10, 6, 27])
# Arrays are typed
>>> arr[1] = "Sarah"
TypeError: an integer is required (got type str)

str — Unicode字符的不可变数组

str是一个不变的字符数组,用于将文本数据存储为Unicode字符。而且,它是一个递归数据结构-字符串中的每个字符本身都是长度为1 的str对象。

字符串对象节省空间,因为它们被紧密包装并且专门用于单一数据类型。由于字符串在Python中是不可变的,因此修改字符串需要创建修改后的副本。


>>> arr = 'Sarah'
>>> arr[1]
'a'
>>> arr
'Sarah'
# String are immutable
>>> arr[1] = 'k'
TypeError: 'str' object does not support item assignment
# Strings are recursive data structures
>>> type('Sarah')
<class 'str'>
>>> type('Sarah'[1])
<class 'str'>

bytes —不可变的单字节数组

字节对象是单个字节的不可变序列(整数范围为0≤x≤255)。从概念上讲,它们类似于str对象。

像字符串一样,字节有其自己的用于创建对象的文字语法,而且它们节省空间。


>>> arr = bytes((22, 30, 10, 6))
>>> arr[1]
30
# Bytes literals have their own syntax
>>> arr
b'\x16\x1e\n\x06'
# Bytes are immutable
>>> arr[1] = 25
TypeError: 'bytes' object does not support item assignment
>>> del arr[1]
TypeError: 'bytes' object doesn't support item deletion
# Only valid bytes are allowed:
>>> bytes((0, 2206))
ValueError: bytes must be in range(0, 256)

bytearray —单字节可变数组

该字节组类型是整数的范围内的可变序列0≤X≤255他们是密切相关的字节与主要区别在于对象的ByteArray可以随意修改-我们可以覆盖的元素,删除或添加新的。该字节组对象将增长,并相应地缩小。

字节数组可以转换回不可变的字节对象,但这涉及到完整复制存储的数据-耗时O(n)的缓慢操作。

>>> arr = bytearray((22, 30, 10, 6))
>>> arr[1]
30
# The bytearray repr:
>>> arr
bytearray(b'\x16\x1e\n\x06')
# bytearrays are mutable
>>> arr[1] = 25
>>> arr[1]
25
>>> arr
bytearray(b'\x16\x19\n\x06')
>>> del arr[1]
>>> arr
bytearray(b'\x16\n\x06')
>>> arr.append(27)
>>> arr
bytearray(b'\x16\n\x06\x1b')
# bytearrays can hold valid bytes
>>> arr[1] = 2206
ValueError: byte must be in range(0, 256)
>>> arr[1] = "Sarah"
TypeError: 'str' object cannot be interpreted as an integer
# bytearrays can be converted back into
# bytes objects
>>> bytes(arr)
b'\x16\n\x06\x1b'

结论:

  • 如果我们要存储具有混合数据类型的任意对象,则可以使用列表或元组对象。
  • 当我们拥有数值数据和紧密包装以及性能很重要时,我们可以尝试使用array.array。
  • 我们可以使用内置的str对象将文本数据表示为Unicode字符。
  • 当我们要存储连续的字节块时,不可变的字节类型或字节数组可以派上用场。

相关推荐

js获取上传文件类型以及大小的方法

前端web上传文件时,需要在上传之前判断一下文件的类型以及文件的大小,HTML为前端的标记语言是无法做到这一点,只能使用javascript动态脚本代码来实现。js获取上传文件大小的方法示例代码:&...

资源分享:移动设备类型判断JS(什么叫移动设备)

相信很多童鞋在实际开发中都会遇到需要判断设备类型来进行不同页面跳转处理,例如手机端访问移动页面,pc端访问pc页面亦或是ios和安卓扫描同一个二维码跳转至不同的下载页面。有这样一种做法当然了你可以使用...

JS学习笔记:三、数据类型(js六中数据类型)

上节知识点回顾:1.什么是变量2.变量的声明3.一次性声明多个变量并赋值4.变量名的规范5.变量的使用本讲内容:数据类型1.数据类型分类原始类型(基本类型)+引用类型原始类型:数字、字符串、布尔类...

JavaScript中常用数据类型,你知道几个?

本文首发自「慕课网」,想了解更多IT干货内容,程序员圈内热闻,欢迎关注!作者|慕课网精英讲师Lison这篇文章我们了解一下JavaScript中现有的八个数据类型,当然这并不是JavaScr...

JS自有类型系统的问题区分竟如此简单?

嗨,我是勾勾。今天想要和你分享的是如何区分强弱类型与JS自有类型系统的问题。类型系统的区分我们在区分不同编程语言时会有一些界定的标准。通常来讲,我们会从类型安全和类型检查上进行区分。类型安全强类型弱类...

抛弃 typeof,这样判断 JavaScript 类型更准确

JavaScript作为一门动态类型语言,类型判断一直是开发者面临的常见挑战。众所周知,typeof操作符存在诸多局限性,无法准确区分数组、对象、null等类型。那么,有没有更精确、更优雅的类型判断方...

有哪些好玩的 Python 代码?(python有什么好玩的项目)

Python是一门非常强大且灵活的编程语言,它不仅可以用来编写复杂的软件应用,还能用来创造一些有趣的小程序和游戏。以下是一些好玩的Python代码示例,涵盖了基础语法、字符串处理、图形绘制等多个...

Python统计快乐8的两码组合数据随机新的两码三码

我们利用Python统计出快乐8的两码组合数据,来生成新的快乐8选二,选三等组合fromcollectionsimportCounterimportrandom#输入新的快乐8两码统计...

10 个鲜为人知的 Python 可视化概念和技巧

数据可视化可视化是我们以各种可视化形式描述数据的操作,从图表、图形到信息图形。它是探索性数据分析(EDA)中最重要的部分之一,因为它使我们能够轻松掌握变量之间的关系以及对后期特征工程和建模有用的数...

用Python搞个随机简单的迷宫(python做迷宫)

为了增加一点趣味打发鼓噪的情绪,玩个简单的迷宫,方便以后搞游戏迷宫。堵路的就简单用#符号吧,如果弄成界面的话可以用图片来,比图墙的图片。因为是随机的,不是固定的一个迷宫,我们少不了random模块...

面试干货——某度Python面试题,转发收藏

目录1、Python是如何进行内存管理的?2、什么是lambda函数?它有什么好处?3、Python里面如何实现tuple和list的转换?4、请写出一段Python代码实现删除一个list里面的重复...

Python while循环深度解析:从基础到实战,一文全掌握!

一、循环的本质:重复执行的魔法在编程世界中,循环是实现自动化的核心工具。想象你需要重复做100次相同的事情,手动编写100次代码显然不现实。这时候,循环就像一位不知疲倦的助手,帮你完成重复性任务。Py...

如何在 Python 中随机排列列表元素

在本教程中,我们将学习在Python中如何打乱列表元素顺序,随机排列列表元素。如何随机排列列表是一项非常有用的技能。它在开发需要选择随机结果游戏中非常有用。它还适用于数据相关的工作中,可能需要提取...

Python快速入门教程7:循环语句(python循环语句有哪些)

一、循环语句简介循环语句用于重复执行一段代码块,直到满足特定条件为止。Python支持两种主要的循环结构:for循环和while循环。二、for循环基本语法for循环用于遍历序列(如列表、元组、字符串...

用Python进行机器学习(6)随机森林

上一节我们讲到了决策树这个算法,但是一棵决策树可能会存在过拟合的现象,而且对数据微小的变化也比较敏感,为了解决这些问题,我们可以通过多棵树的方式,也就是今天要介绍的随机森林。随机森林算法也就是Rand...

取消回复欢迎 发表评论: