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

python散装笔记——17: 数组_python中数组操作

liuian 2025-02-18 12:23 19 浏览


Parameter

Details

b

表示大小为 1 字节的带符号整数

B

表示大小为 1 字节的无符号整数

c

表示大小为 1 字节的字符

u

表示大小为 2 字节的统一码字符

h

表示大小为 2 字节的带符号整数

H

表示大小为 2 字节的无符号整数

i

表示大小为 2 字节的带符号整数

I

表示大小为 2 字节的无符号整数

w

表示大小为 4 字节的统一码字符

l

表示大小为 4 字节的带符号整数

L

表示大小为 4 字节的无符号整数

f

表示大小为 4 字节的浮点数

d

表示大小为 8 字节的浮点数

Python 中的 “数组 ”与 C 和 Java 等传统编程语言中的数组不同,更接近于列表。列表可以是同质元素或异质元素的集合,可以包含 intstring 或其他列表。

1: 通过索引访问单个元素

可以通过索引访问单个元素。Python 数组的索引为零。下面是的例子

my_array = array('i', [1,2,3,4,5])
print(my_array[1])
# 2
print(my_array[2])
# 3
print(my_array[0])
# 1

2: 数组基础入门

数组是一种存储相同数据类型值的数据结构。在 Python 中,这是数组与列表的主要区别。

Python 列表可以包含不同数据类型的值,而数组只能包含相同数据类型的值。在本教程中,我们将通过几个示例来了解 Python 数组。

如果您是 Python 的新手,请从 Python 入门文章开始学习。

要在 Python 语言中使用数组,需要导入标准数组模块。这是因为数组不像字符串、整数等那样是基本数据类型。下面是在 python 中导入数组模块的方法:

from array import *

导入数组模块后,就可以声明一个数组。具体操作如下

arrayIdentifierName = array(typecode, [Initializers])

在上面的声明中,arrayIdentifierName 是数组的名称,typecode 让 python 知道数组的类型,Initializers 是数组的初始化值。

Typecode 是用来定义数组值类型或数组类型的代码。参数部分的表格显示了在声明数组时可能使用的值及其类型。

下面是一个 Python 数组声明的真实示例:

my_array = array('i',[1,2,3,4])

在上面的示例中,使用的类型码是 i。该类型码表示大小为 2 字节的带符号整数。

下面是一个包含 5 个整数的数组的简单示例

from array import *
my_array = array('i', [1,2,3,4,5])
for i in my_array:
  print(i)

# 1
# 2
# 3
# 4
# 5

3: 使用 append() 方法将任意值添加到数组中

my_array = array('i', [1,2,3,4,5])
my_array.append(6)
# array('i', [1, 2, 3, 4, 5, 6])

请注意,数值 6 已添加到现有数组值中。

4: 使用 insert() 方法在数组中插入数值

我们可以使用 insert() 方法在数组的任意索引处插入一个值。下面是一个示例:

my_array = array('i', [1,2,3,4,5])
my_array.insert(0,0)
#array('i', [0, 1, 2, 3, 4, 5])

在上例中,值 0 被插入索引 0。请注意,第一个参数是索引,而第二个参数是值。

5: 使用 extend() 方法扩展 python 数组

使用 extend() 方法,一个 python 数组可以扩展多个值。下面是一个例子:

my_array = array('i', [1,2,3,4,5])
my_extnd_array = array('i', [7,8,9,10])
my_array.extend(my_extnd_array)
# array('i', [1, 2, 3, 4, 5, 7, 8, 9, 10])

我们可以看到数组 my_array 扩展了来自 my_extnd_array 的值。

6: 使用 fromlist() 方法将列表中的项目添加到数组中

下面举一个例子:

my_array = array('i', [1,2,3,4,5])
c=[11,12,13]
my_array.fromlist(c)
# array('i', [1, 2, 3, 4, 5, 11, 12, 13])

因此,我们看到值 111213 已从 list c 添加到 my_array 中。

7: 使用 remove() 方法删除任何数组元素

下面举一个例子:

my_array = array('i', [1,2,3,4,5])
my_array.remove(4)
# array('i', [1, 2, 3, 5])

我们可以看到,元素 4 已从数组中删除。

8: 使用 pop() 方法删除最后一个数组元素

我们可以看到,元素 4 已从数组中删除。

my_array = array('i', [1,2,3,4,5])
my_array.pop()
# array('i', [1, 2, 3, 4])

因此,我们看到最后一个元素(5)从数组中弹出。

9: 使用 index() 方法通过索引获取任何元素

index() 返回匹配值的第一个索引。请记住,数组的索引从零开始。

my_array = array('i', [1,2,3,4,5])
print(my_array.index(5))
# 4

my_array = array('i', [1,2,3,3,5])
print(my_array.index(3))
# 2

请注意,在第二个示例中,虽然数值在数组中存在两次,但只返回了一个索引

10: 使用 reverse() 方法反转 python 数组

reverse() 方法的作用正如其名:反转数组。下面是一个示例:

my_array = array('i', [1,2,3,4,5])
my_array.reverse()
# array('i', [5, 4, 3, 2, 1])

11: 通过 buffer_info() 方法获取数组缓冲信息

该方法提供数组缓冲区在内存中的起始地址和数组中的元素数。下面是一个示例,执行的输出结果中内存地址会因不同的电脑和系统不一样:

my_array = array('i', [1,2,3,4,5])
my_array.buffer_info()
(140424627745360, 5)

12: 使用 count() 方法检查元素的出现次数

count() 将返回元素在数组中出现的次数。在下面的示例中,我们看到值 3 出现了两次。

my_array = array('i', [1,2,3,3,5])
my_array.count(3)
# 2

13: 使用 tolist() 方法将数组转换为具有相同元素的 python 列表

当您需要 Python 列表对象时,可以使用 tolist() 方法将数组转换为列表。

my_array = array('i', [1,2,3,4,5])
c = my_array.tolist()
# [1, 2, 3, 4, 5]




相关推荐

总结下SpringData JPA 的常用语法

SpringDataJPA常用有两种写法,一个是用Jpa自带方法进行CRUD,适合简单查询场景、例如查询全部数据、根据某个字段查询,根据某字段排序等等。另一种是使用注解方式,@Query、@Modi...

解决JPA在多线程中事务无法生效的问题

在使用SpringBoot2.x和JPA的过程中,如果在多线程环境下发现查询方法(如@Query或findAll)以及事务(如@Transactional)无法生效,通常是由于S...

PostgreSQL系列(一):数据类型和基本类型转换

自从厂子里出来后,数据库的主力就从Oracle变成MySQL了。有一说一哈,贵确实是有贵的道理,不是开源能比的。后面的工作里面基本上就是主MySQL,辅MongoDB、ES等NoSQL。最近想写一点跟...

基于MCP实现text2sql

目的:基于MCP实现text2sql能力参考:https://blog.csdn.net/hacker_Lees/article/details/146426392服务端#选用开源的MySQLMCP...

ORACLE 错误代码及解决办法

ORA-00001:违反唯一约束条件(.)错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。ORA-00017:请求会话以设置跟踪事件ORA-00018:超出最大会话数ORA-00...

从 SQLite 到 DuckDB:查询快 5 倍,存储减少 80%

作者丨Trace译者丨明知山策划丨李冬梅Trace从一开始就使用SQLite将所有数据存储在用户设备上。这是一个非常不错的选择——SQLite高度可靠,并且多种编程语言都提供了广泛支持...

010:通过 MCP PostgreSQL 安全访问数据

项目简介提供对PostgreSQL数据库的只读访问功能。该服务器允许大型语言模型(LLMs)检查数据库的模式结构,并执行只读查询操作。核心功能提供对PostgreSQL数据库的只读访问允许L...

发现了一个好用且免费的SQL数据库工具(DBeaver)

缘起最近Ai不是大火么,想着自己也弄一些开源的框架来捣腾一下。手上用着Mac,但Mac都没有显卡的,对于学习Ai训练模型不方便,所以最近新购入了一台4090的拯救者,打算用来好好学习一下Ai(呸,以上...

微软发布.NET 10首个预览版:JIT编译器再进化、跨平台开发更流畅

IT之家2月26日消息,微软.NET团队昨日(2月25日)发布博文,宣布推出.NET10首个预览版更新,重点改进.NETRuntime、SDK、libraries、C#、AS...

数据库管理工具Navicat Premium最新版发布啦

管理多个数据库要么需要使用多个客户端应用程序,要么找到一个可以容纳你使用的所有数据库的应用程序。其中一个工具是NavicatPremium。它不仅支持大多数主要的数据库管理系统(DBMS),而且它...

50+AI新品齐发,微软Build放大招:拥抱Agent胜算几何?

北京时间5月20日凌晨,如果你打开微软Build2025开发者大会的直播,最先吸引你的可能不是一场原本属于AI和开发者的技术盛会,而是开场不久后的尴尬一幕:一边是几位微软员工在台下大...

揭秘:一条SQL语句的执行过程是怎么样的?

数据库系统能够接受SQL语句,并返回数据查询的结果,或者对数据库中的数据进行修改,可以说几乎每个程序员都使用过它。而MySQL又是目前使用最广泛的数据库。所以,解析一下MySQL编译并执行...

各家sql工具,都闹过哪些乐子?

相信这些sql工具,大家都不陌生吧,它们在业内绝对算得上第一梯队的产品了,但是你知道,他们都闹过什么乐子吗?首先登场的是Navicat,这款强大的数据库管理工具,曾经让一位程序员朋友“火”了一把。Na...

详解PG数据库管理工具--pgadmin工具、安装部署及相关功能

概述今天主要介绍一下PG数据库管理工具--pgadmin,一起来看看吧~一、介绍pgAdmin4是一款为PostgreSQL设计的可靠和全面的数据库设计和管理软件,它允许连接到特定的数据库,创建表和...

Enpass for Mac(跨平台密码管理软件)

还在寻找密码管理软件吗?密码管理软件有很多,但是综合素质相当优秀且完全免费的密码管理软件却并不常见,EnpassMac版是一款免费跨平台密码管理软件,可以通过这款软件高效安全的保护密码文件,而且可以...