目录
使用 List 创建数组使用数组函数创建数组使用 numpy 方法创建数组重塑数组展平数组在 Numpy 中创建数组的方法使用 List 创建数组
数组用于在一个变量中存储多个值。Python 没有对数组的内置支持,但可以使用 Python 列表代替。
例子 :
【资料图】
arr = [1, 2, 3, 4, 5] arr1 = ["geeks", "for", "geeks"]
# 用于创建数组的 Python 程序
# 使用列表创建数组
arr=[1, 2, 3, 4, 5]
for i in arr:
print(i)
输出:
1
2
3
4
5
使用数组函数创建数组
array(data type, value list)函数用于创建一个数组,其参数中指定了数据类型和值列表。
例子 :
# 演示 array() 工作的 Python 代码
# 为数组操作导入“array”
import array
# 用数组值初始化数组
# 用有符号整数初始化数组
arr = array.array("i", [1, 2, 3])
# 打印原始数组
print ("The new created array is : ",end="")
for i in range (0,3):
print (arr[i], end=" ")
print ("\r")
输出:
The new created array is : 1 2 3 1 5
使用 numpy 方法创建数组
NumPy 提供了几个函数来创建具有初始占位符内容的数组。这些最大限度地减少了增长阵列的必要性,这是一项昂贵的操作。例如:np.zeros、np.empty等。
numpy.empty(shape, dtype = float, order = "C"):返回给定形状和类型的新数组,具有随机值。
# 说明 numpy.empty 方法的 Python 代码
import numpy as geek
b = geek.empty(2, dtype = int)
print("Matrix b : \n", b)
a = geek.empty([2, 2], dtype = int)
print("\nMatrix a : \n", a)
c = geek.empty([3, 3])
print("\nMatrix c : \n", c)
输出 :
Matrix b :
[ 0 1079574528]
Matrix a :
[[0 0]
[0 0]]
Matrix a :
[[ 0. 0. 0.]
[ 0. 0. 0.]
[ 0. 0. 0.]]
numpy.zeros(shape, dtype = None, order = "C"):返回给定形状和类型的新数组,带零。
# 说明 numpy.zeros 方法的 Python 程序
import numpy as geek
b = geek.zeros(2, dtype = int)
print("Matrix b : \n", b)
a = geek.zeros([2, 2], dtype = int)
print("\nMatrix a : \n", a)
c = geek.zeros([3, 3])
print("\nMatrix c : \n", c)
输出 :
Matrix b :
[0 0]
Matrix a :
[[0 0]
[0 0]]
Matrix c :
[[ 0. 0. 0.]
[ 0. 0. 0.]
[ 0. 0. 0.]]
重塑数组
我们可以使用reshape方法来重塑数组。考虑一个形状为 (a1, a2, a3, ..., aN) 的数组。我们可以重新整形并将其转换为另一个形状为 (b1, b2, b3, ..., bM) 的数组。
唯一需要的条件是: a1 x a2 x a3 … x aN = b1 x b2 x b3 … x bM 。(即数组的原始大小保持不变。)
numpy.reshape(array, shape, order = "C"):在不更改数组数据的情况下对数组进行整形。
# 说明 numpy.reshape() 方法的 Python 程序
import numpy as geek
array = geek.arange(8)
print("Original array : \n", array)
# 具有 2 行和 4 列的形状数组
array = geek.arange(8).reshape(2, 4)
print("\narray reshaped with 2 rows and 4 columns : \n", array)
# 具有 2 行和 4 列的形状数组
array = geek.arange(8).reshape(4 ,2)
print("\narray reshaped with 2 rows and 4 columns : \n", array)
# 构造 3D 数组
array = geek.arange(8).reshape(2, 2, 2)
print("\nOriginal array reshaped to 3D : \n", array)
输出 :
Original array :
[0 1 2 3 4 5 6 7]
array reshaped with 2 rows and 4 columns :
[[0 1 2 3]
[4 5 6 7]]
array reshaped with 2 rows and 4 columns :
[[0 1]
[2 3]
[4 5]
[6 7]]
Original array reshaped to 3D :
[[[0 1]
[2 3]]
[[4 5]
[6 7]]]
为了创建数字序列,NumPy 提供了一个类似于 range 的函数,它返回数组而不是列表。
arange返回给定间隔内均匀分布的值。步长是指定的。
linspace返回给定间隔内均匀分布的值。编号_的元素被返回。
arange([start,] stop[, step,][, dtype]):根据间隔返回一个具有均匀间隔元素的数组。提到的间隔是半开的,即[开始,停止)
# 说明 numpy.arange 方法的 Python 编程
import numpy as geek
print("A\n", geek.arange(4).reshape(2, 2), "\n")
print("A\n", geek.arange(4, 10), "\n")
print("A\n", geek.arange(4, 20, 3), "\n")
输出 :
A
[[0 1]
[2 3]]
A
[4 5 6 7 8 9]
A
[ 4 7 10 13 16 19]
numpy.linspace(start, stop, num = 50, endpoint = True, retstep = False, dtype = None):在间隔中均匀返回数字空间。类似于 arange 但不是 step 它使用样本编号。
# 说明 numpy.linspace 方法的 Python 编程
import numpy as geek
# 重新设置为 True
print("B\n", geek.linspace(2.0, 3.0, num=5, retstep=True), "\n")
# 长期评估 sin()
x = geek.linspace(0, 2, 10)
print("A\n", geek.sin(x))
输出 :
B
(array([ 2. , 2.25, 2.5 , 2.75, 3. ]), 0.25)
A
[ 0. 0.22039774 0.42995636 0.6183698 0.77637192 0.8961922
0.9719379 0.99988386 0.9786557 0.90929743]
展平数组
我们可以使用展平方法将数组的副本折叠成一维。它接受 order 参数。默认值为“C”(用于行优先顺序)。使用“F”表示列主要顺序。
numpy.ndarray.flatten(order = "C"):返回折叠成一维的数组的副本。
# 说明 numpy.flatten() 方法的 Python 程序
import numpy as geek
array = geek.array([[1, 2], [3, 4]])
# 使用扁平化方法
array.flatten()
print(array)
#使用扁平化方法
array.flatten("F")
print(array)
输出 :
[1, 2, 3, 4]
[1, 3, 2, 4]
在 Numpy 中创建数组的方法
| 功能 | 描述 |
|---|---|
| empty() | 返回给定形状和类型的新数组,而不初始化条目 |
| empty_like() | 返回与给定数组具有相同形状和类型的新数组 |
| eye() | 返回一个二维数组,其中对角线为 1,其他位置为 0。 |
| identity() | 返回标识数组 |
| ones() | 返回一个给定形状和类型的新数组,用一个填充 |
| one_like() | 返回与给定数组具有相同形状和类型的数组 |
| zeros() | 返回给定形状和类型的新数组,用零填充 |
| zeros_like() | 返回与给定数组具有相同形状和类型的零数组 |
| full_like() | 返回与给定数组具有相同形状和类型的完整数组。 |
| array() | 创建一个数组 |
| asarray() | 将输入转换为数组 |
| asanyarray() | 将输入转换为 ndarray,但通过 ndarray 子类 |
| ascontiguousarray() | 返回内存中的连续数组(C 顺序) |
| asmatrix() | 将输入解释为矩阵 |
| copy() | 返回给定对象的数组副本 |
| frombuffer() | 将缓冲区解释为一维数组 |
| fromfile() | 从文本或二进制文件中的数据构造数组 |
| fromfunction() | 通过在每个坐标上执行函数来构造数组 |
| fromiter() | 从可迭代对象创建一个新的一维数组 |
| fromstring() | 从字符串中的文本数据初始化的新一维数组 |
| loadtxt() | 从文本文件加载数据 |
| arange() | 在给定间隔内返回均匀间隔的值 |
| linspace() | 在指定的时间间隔内返回均匀分布的数字 |
| logspace() | 返回在对数刻度上均匀分布的数字 |
| geomspace() | 返回在对数尺度上均匀分布的数字(几何级数) |
| meshgrid() | 从坐标向量返回坐标矩阵 |
| mgrid() | nd_grid 实例,它返回一个密集的多维“网格” |
| ogrid() | nd_grid 实例,它返回一个开放的多维“meshgrid” |
| diag() | 提取对角线或构造对角线数组 |
| diagflat() | 创建一个二维数组,将扁平化输入作为对角线 |
| tri() | 一个数组,在给定的对角线处和下方都有一个,在其他地方有零 |
| tril() | 数组的下三角形 |
| triu() | 数组的上三角形 |
| vander() | 生成范德蒙德矩阵 |
| mat() | 将输入解释为矩阵 |
| bmat() | 从字符串、嵌套序列或数组构建矩阵对象 |
到此这篇关于Python NumPy教程之数组的创建详解的文章就介绍到这了,更多相关Python NumPy数组创建内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
X 关闭
X 关闭
- 1联想拯救者Y70发布最新预告:售价2970元起 迄今最便宜的骁龙8+旗舰
- 2亚马逊开始大规模推广掌纹支付技术 顾客可使用“挥手付”结账
- 3现代和起亚上半年出口20万辆新能源汽车同比增长30.6%
- 4如何让居民5分钟使用到各种设施?沙特“线性城市”来了
- 5AMD实现连续8个季度的增长 季度营收首次突破60亿美元利润更是翻倍
- 6转转集团发布2022年二季度手机行情报告:二手市场“飘香”
- 7充电宝100Wh等于多少毫安?铁路旅客禁止、限制携带和托运物品目录
- 8好消息!京东与腾讯续签三年战略合作协议 加强技术创新与供应链服务
- 9名创优品拟通过香港IPO全球发售4100万股 全球发售所得款项有什么用处?
- 10亚马逊云科技成立量子网络中心致力解决量子计算领域的挑战

