我是Python的新手,此代码中有些我不理解的东西:

import numpy as np

a_list = []
sub_list = ["apple", "banana", "cherry"]

a_list.append(sub_list)

print(type(a_list))
print(type(a_list[0]))
print(type(sub_list))

array = np.array(a_list)

print(type(array))
print(type(array[0]))
print(type(sub_list))
print(array[0])


运行它时,得到以下输出:

<class 'list'>
<class 'list'>
<class 'list'>
<class 'numpy.ndarray'>
<class 'numpy.ndarray'>
<class 'list'>
['apple' 'banana' 'cherry']


为什么type(array[0])也是numpy.ndarray?不应该是清单吗?

最佳答案

In [36]:
    ...: a_list = []
    ...: sub_list = ["apple", "banana", "cherry"]
    ...:
    ...: a_list.append(sub_list)
In [37]: arr = np.array(a_list)
In [38]: a_list
Out[38]: [['apple', 'banana', 'cherry']]
In [39]: arr
Out[39]: array([['apple', 'banana', 'cherry']], dtype='<U6')
In [40]: arr[0]
Out[40]: array(['apple', 'banana', 'cherry'], dtype='<U6')
In [41]: arr.shape
Out[41]: (1, 3)


np.array尝试根据其输入创建多维数组。 a_list是一个嵌套列表,可以从中创建2d数组。 arr[0]是从arr中选择的一维数组。

arr不是列表数组。它是一个字符串元素数组。

可以创建一个包含列表的数组:

In [42]: arr1 = np.empty(1, object)
In [43]: arr1
Out[43]: array([None], dtype=object)
In [44]: arr1[0]=sub_list
In [45]: arr1
Out[45]: array([list(['apple', 'banana', 'cherry'])], dtype=object)
In [46]: arr1[0]
Out[46]: ['apple', 'banana', 'cherry']


但是对于大多数用途来说,它比a_list列表好一点,并且在某些方面更糟(例如,不能使用.append)。

从嵌套列表制作二维数组的经典案例:

In [47]: np.array([[1,2,3],[4,5,6]])
Out[47]:
array([[1, 2, 3],
       [4, 5, 6]])
In [48]: _.shape
Out[48]: (2, 3)


此纯数字数组的数学运算比包含列表的对象dtype数组要快得多。 Python已经有可嵌套列表。

10-06 01:08
查看更多