Numpy 用现有数据创建数组
在本章中,我们将讨论如何从现有数据创建数组。
numpy.asarray
该函数与 numpy.array 类似,只是它的参数较少。此例程对于将 Python 序列转换为 ndarray 很有用。
numpy.asarray(a, dtype = None, order = None)
构造函数采用以下参数。
序号. | 参数及说明 |
---|---|
1 | a 以任何形式输入数据,例如列表、元组列表、元组、元组元组或列表元组 |
2 | dtype 默认情况下,输入数据的数据类型应用于结果 ndarray |
3 | order C(行专业)或 F(列专业)。 C 是默认值 |
以下示例展示了如何使用asarray函数。
示例 1
# convert list to ndarray import numpy as np x = [1,2,3] a = np.asarray(x) print a
它的输出如下:
[1 2 3]
示例 2
# dtype is set import numpy as np x = [1,2,3] a = np.asarray(x, dtype = float) print a
现在,输出如下:
[ 1. 2. 3.]
示例 3
# ndarray from tuple import numpy as np x = (1,2,3) a = np.asarray(x) print a
它的输出将是:
[1 2 3]
示例 4
# ndarray from list of tuples import numpy as np x = [(1,2,3),(4,5)] a = np.asarray(x) print a
在这里,输出如下:
[(1, 2, 3) (4, 5)]
numpy.frombuffer
此函数将缓冲区解释为一维数组。任何暴露缓冲区接口的对象都用作参数来返回一个ndarray.
numpy.frombuffer(buffer, dtype = float, count = -1, offset = 0)
构造函数采用以下参数。
序号. | 参数及说明 |
---|---|
1 | buffer 任何暴露缓冲区接口的对象 |
2 | dtype 返回的 ndarray 的数据类型。默认为浮动 |
3 | count 要读取的项目数,默认 -1 表示所有数据 |
4 | offset 要读取的起始位置。默认为 0 |
下面的例子演示了使用frombuffer函数。
import numpy as np s = 'Hello World' a = np.frombuffer(s, dtype = 'S1') print a
这是它的输出:
['H' 'e' 'l' 'l' 'o' ' ' 'W' 'o' 'r' 'l' 'd']
numpy.fromiter
该函数构建了一个ndarray来自任何可迭代对象的对象。此函数返回一个新的一维数组。
numpy.fromiter(iterable, dtype, count = -1)
在这里,构造函数采用以下参数。
序号. | 参数及说明 |
---|---|
1 | iterable 任何可迭代对象 |
2 | dtype 结果数组的数据类型 |
3 | count 要从迭代器读取的项目数。默认为 -1,表示要读取的所有数据 |
下面的例子展示了如何使用内置的range()函数返回一个列表对象。此列表的迭代器用于形成一个ndarray对象。
示例 1
# create list object using range function import numpy as np list = range(5) print list
其输出如下:
[0, 1, 2, 3, 4]
示例 2
# obtain iterator object from list import numpy as np list = range(5) it = iter(list) # use iterator to create ndarray x = np.fromiter(it, dtype = float) print x
现在,输出如下:
[0. 1. 2. 3. 4.]