如何在Python中声明数组?


当前回答

variable = []

现在变量指向一个空列表*。

当然,这是赋值,不是声明。因为Python是动态类型的,所以在Python中没有办法说“这个变量永远不应该指列表以外的任何东西”。


*默认的内置Python类型称为列表,而不是数组。它是一个任意长度的有序容器,可以容纳异构的对象集合(它们的类型无关紧要,可以自由混合)。这不应该与array模块混淆,后者提供了一种更接近C数组类型的类型;内容必须是同质的(都是同一类型),但是长度仍然是动态的。

其他回答

我通常只写a =[1,2,3],这实际上是一个列表,但对于数组,看看这个正式的定义

你不需要在Python中声明任何东西。你只需使用它。我建议你从http://diveintopython.net开始。

JohnMachin的评论才是真正的答案。 在我看来,所有其他答案都只是变通方法! 所以:

array=[0]*element_count

我认为你(意思是)想要一个列表与前30个单元格已经填补。 所以

   f = []

   for i in range(30):
       f.append(0)

斐波那契数列就是一个例子。 参见Project Euler中的问题2

计算时,使用numpy数组:

import numpy as np

a = np.ones((3,2))        # a 2D array with 3 rows, 2 columns, filled with ones
b = np.array([1,2,3])     # a 1D array initialised using a list [1,2,3]
c = np.linspace(2,3,100)  # an array with 100 points beteen (and including) 2 and 3

print(a*1.5)  # all elements of a times 1.5
print(a.T+b)  # b added to the transpose of a

这些numpy数组可以从磁盘保存和加载(甚至压缩),具有大量元素的复杂计算像c一样快。

多用于科学环境。更多信息请看这里。