| 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 等传统编程语言中的数组不同,更接近于列表。列表可以是同质元素或异质元素的集合,可以包含 int、string 或其他列表。
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])
因此,我们看到值 11、12 和 13 已从 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]