1 使用list初始化

a=np.array([[1,2,3],[4,5,6]],dtype='float32')
#a=[[1. 2. 3.],[4. 5. 6.]]

2 赋值与复制

(1)赋值

a=np.array([1,2,3])
b=a
print(b is a) #True b[0]=0
print(a) #[0 2 3]
print(b) #[0 2 3]
print(b is a) #True

在赋值情形下,b 和 a 指向同一块地址,b 改变,a 也随着改变 。

a=np.array([1,2,3])
b=a[:2]
print(b is a) #False b[0]=0
print(a) #[0 2 3]
print(b) #[0 2]

在使用切片时,切片改变,原数据也会改变。

(2)复制

a=np.array([1,2,3])
b=a.copy()
print(b is a) #False b[0]=0
print(a) #[1 2 3]
print(b) #[0 2 3]

在复制情形下,b和a指向不同地址,b改变,a不会改变

3 随机数初始化

3.1 区间内随机数

(1)np.random.uniform(low=0.0, high=1.0, size=None)

简介:生成 [low,high) 内的 size 个随机数,默认 [0,1) 之间,size 是 int 型或元组

a=np.random.uniform() #产生[0,1)内的1个随机数
#a=0.1973408987805232 b=np.random.uniform(10,20,2) #产生[10,20)内的2个随机数
#b=[10.15492129 12.8762581] c=np.random.uniform(1,5,(2,3)) #产生[1,5)内2*3个随机数
#c=[[1.89354111 4.01642541 1.63691704],[3.23261205 4.81380553 4.51288251]]

(2)np.random.rand(d0,d1,...,dn)

简介:生成 [0,1) 内的 d0*d1*...*dn 个浮点数,d0,d1,...,dn 表示数组维度

a=np.random.rand() #产生[0,1)内的1个随机数
#a=0.7114622255979923 b=np.random.rand(2) #产生[0,1)内的2个随机数
#b=[0.39094731 0.32324018] c=np.random.rand(2,3) #产生[0,1)内的2*3个随机数
#c=[[0.30305566 0.70335946 0.71778137],[0.03069973 0.20145633 0.70092122]]

(3)np.random.randint(low, high=None, size=None, dtype=’l’)

简介:生成 [low,high) 内的 size 个整型随机数,默认1个 [0,low) 内的随机整数

a=np.random.randint(10) #产生[0,10)内的1个随机整数
#a=6 b=np.random.randint(10,20) #产生[10,20)内的1个随机整数
#b=14 c=np.random.randint(1,5,(2,3)) #产生[1,5)内的2*3个随机整数
#c=[[4 2 2],[3 2 1]]

3.2 随机全排列

(1) np.random.permutation(n)

简介:若 n 为 int,生成 0~n-1 的一个随机排列;若 n 为数组,生成此数组的一个随机排列

a=np.random.permutation(10)
#a=[5 9 6 8 7 4 0 3 1 2] x=np.array([2.2,4.4,6.6,8.8])
b=np.random.permutation(x) #x不变,b随机
#b=[6.6 2.2 4.4 8.8]

(2)np.random.shuffle(arr)

简介:将数组 arr 随机打乱

a=np.array([1,3,5,7,9,0,2,4,6,8])
np.random.shuffle(a)
#a=[6 5 9 8 0 3 4 2 1 7]

3.3 随机部分排列

np.random.choice(a, size=None, replace=True, p=None)

简介:若 a 为 int,从 0~a-1 中随机挑选 size 个数排列;若 a 为数组,则从此数组中随机挑选 size 个数排列。replace 表示是否允许元素重复

a=np.random.choice(10,7,replace=False)
#a=[2 7 0 1 8 4 3] x=['a','b','c','d','e','f','g','h','i','j']
b=np.random.choice(x,5,replace=False)
#b=['b' 'd' 'c' 'i' 'e']

4 全0与全1初始化

a=np.zeros(5,dtype='int32')
#a=[0 0 0 0 0] b=np.zeros((2,3),dtype='int32')
#b=[[0 0 0],[0 0 0]] c=np.ones(5,dtype='int32')
#c=[1 1 1 1 1] d=np.ones((2,3),dtype='int32')
#d=[[1 1 1],[1 1 1]]

5 等步长连续序列初始化

(1)np.arange(min,max,step=1)

简介:生成 [min,max) 之间步长为 step 的序列,步长默认为1

a=np.arange(2,6)
#a=[2 3 4 5] b=np.arange(2,3,0.2)
#b=[2. 2.2 2.4 2.6 2.8]

(2)np.linspace(min,max,num=50)

简介:生成 [min,max] 之间长度为num的序列,长度默认为50

a=np.linspace(6,8,5)
#a=[6. 6.5 7. 7.5 8.] b=np.linspace(1,99)
#b=
#[1. 3. 5. 7. 9. 11. 13. 15. 17. 19. 21. 23. 25. 27. 29. 31. 33. 35.
# 37. 39. 41. 43. 45. 47. 49. 51. 53. 55. 57. 59. 61. 63. 65. 67. 69. 71.
# 73. 75. 77. 79. 81. 83. 85. 87. 89. 91. 93. 95. 97. 99.]

​ 说明:本文转自numpy数组初始化方法总结

numpy数组初始化方法总结的更多相关文章

  1. C++数组初始化方法

    定义: ]; // array of 10 uninitialized ints 此 new 表达式分配了一个含有 10 个 int 型元素的数组,并返回指向该数组第一个元素的指针,此返回值初始化了指 ...

  2. 05.其他创建numpy数组的方法

    >>> import numpy as np >>> np.zeros(10,dtype=int) array([0, 0, 0, 0, 0, 0, 0, 0, 0 ...

  3. Python数据分析工具库-Numpy 数组支持库(一)

    1 Numpy数组 在Python中有类似数组功能的数据结构,比如list,但在数据量大时,list的运行速度便不尽如意,Numpy(Numerical Python)提供了真正的数组功能,以及对数据 ...

  4. Numpy数组对象的操作-索引机制、切片和迭代方法

    前几篇博文我写了数组创建和数据运算,现在我们就来看一下数组对象的操作方法.使用索引和切片的方法选择元素,还有如何数组的迭代方法. 一.索引机制 1.一维数组 In [1]: a = np.arange ...

  5. C语言 数组初始化的三种常用方法({0}, memset, for循环赋值)以及原理

    C语言中,数组初始化的方式主要有三种: 1.声明时,使用 {0} 初始化: 2.使用memset: 3.用for循环赋值. 那么,这三种方法的原理以及效率如何呢? 请看下面的测试代码: #define ...

  6. 轻轻松松了解Java的初始化方法(含对象数组的小问题)

    Java基础复习6-初始化 之前讲过了类的一些基础,想必大家都知道了类的定义 什么?你忘了? 下面给你一个例子快速复习 class AClass{ int a; boolean b; void get ...

  7. 通过数组初始化链表的两种方法:指向指针的引用node *&tail和指向指针的指针(二维指针)node **tail

    面试高频题:单链表的逆置操作/链表逆序相关文章 点击打开 void init_node(node *tail,char *init_array) 这样声明函数是不正确的,函数的原意是通过数组初始化链表 ...

  8. numpy数组、向量、矩阵运算

    可以来我的Github看原文,欢迎交流. https://github.com/AsuraDong/Blog/blob/master/Articles/%E6%9C%BA%E5%99%A8%E5%AD ...

  9. NumPy 超详细教程(1):NumPy 数组

    系列文章地址 NumPy 最详细教程(1):NumPy 数组 NumPy 超详细教程(2):数据类型 NumPy 超详细教程(3):ndarray 的内部机理及高级迭代 文章目录 Numpy 数组:n ...

  10. numpy的使用方法

    一.numpy快速入门 1.什么是numpy: numpy是python的一个矩阵类型,提供了大量矩阵处理的函数,非正式来说,就是一个使运算更容易,执行更迅速的库,因为它的内部运算是通过c语言而不是p ...

随机推荐

  1. ORA-65140: 无效的通用配置文件名称

    1.问题 CREATE PROFILE PM_Profile LIMIT SESSIONS_PER_USER 100 PASSWORD_LIFE_TIME 90; 在创建概要文件时,报错:ORA-65 ...

  2. 【Printf】CubeMX生成MDK工程实现printf功能注意点

    重定向printf int fputc(int ch, FILE *f) { /* Write a character to the USART */ USART1->DR = ch; /* L ...

  3. [转帖]002、体系结构之TiDB Server

    TiDB Server 1.TiDB总览 1.1.TiDB Server架构 1.2.TiDB Server 主要功能: 2.SQL语句处理 语句的解析和编译 SQL层 协议层 上下文 解析层 逻辑优 ...

  4. [转帖]看看 Jmeter 是如何玩转 redis 数据库的

    柠檬小欧 2021-08-31 20:06420 Jmeter 作为当前非常受欢迎的接口测试和性能测试的工具,在企业中得到非常广泛的使用,而 Redis 作为缓存数据库,也在企业中得到普遍使用,那如何 ...

  5. [转帖]Nginx应用调优案例

    https://bbs.huaweicloud.com/blogs/146367 [摘要] 1 问题背景nginx的应用程序移植到TaiShan服务器上,发现业务吞吐量没有达到硬件预期,需要做相应调优 ...

  6. [转帖]超能课堂(323) 为什么WiFi实际速率只有标称速率的一半?

    超能课堂(323) 为什么WiFi实际速率只有标称速率的一半? 开始的地方 协议速率与实际速率有何不同? 什么是"全双工"与"半双工"? 无线网络与有线网络的抗 ...

  7. [转帖]IPv6地址解析库,窥探IPv6地址中包含的信息

    https://zhuanlan.zhihu.com/p/479028720 大家好,我是明说网络的小明同学. 今天和大家介绍一个IPv6 地址解析库IPv6 address Parser :http ...

  8. [1036]kvm虚拟机访问时提示no route to host分析

    环境 宿主机: IP: 10.110.136.43 版本:Kylin Linux Advanced Server release V10 (Sword) KVM vm: IP: 10.110.136. ...

  9. firewall-cmd 命令简单总结

    最近进行相关网络设置, 发现需要总结一下不然总是会忘记. # 1. 开放IP地址访问 firewall-cmd --zone=trusted --add-source=yourip --permane ...

  10. 【解决一个小问题】golang 的 `-race`选项导致 unsafe代码 panic

    作者:张富春(ahfuzhang),转载时请注明作者和引用链接,谢谢! cnblogs博客 zhihu Github 公众号:一本正经的瞎扯 为了提升性能,使用 unsafe 代码来重构了凯撒加密的代 ...