NumPy学习_00 ndarray的创建
1.使用array()函数创建数组
参数可以为:单层或嵌套列表;嵌套元组或元组列表;元组或列表组成的列表
# 导入numpy库
import numpy as np
# 由单层列表创建
a = np.array([1, 2, 3])
print(a)
[1 2 3]
# 由嵌套列表创建
b = np.array([[1.3, 2.4], [0.3, 4.1]])
print(b)
[[1.3 2.4]
[0.3 4.1]]
# 由嵌套元组创建
c = np.array((("p", "y", "t"), ("h", "o", "n")))
print(c)
[['p' 'y' 't']
['h' 'o' 'n']]
# 由元组列表创建
d = np.array([(3, 2, 1), (7, 8, 9)])
print(d)
[[3 2 1]
[7 8 9]]
# 由元组或列表组成的列表
e = np.array([(6, 1, 8), [7, 5, 3], (2, 9, 4)])
print(e)
[[6 1 8]
[7 5 3]
[2 9 4]]
# array创建数组返回的类型
print(type(a))
<class 'numpy.ndarray'>
2.数据类型
# 数组元素是同质的,即类型和大小都相同
# 数据类型由dtype对象来指定
# itemsize属性,定义了数组中每个元素的长度占几个字节
print(a.dtype.name, a.itemsize)
print(b.dtype.name, b.itemsize)
print(c.dtype.name, c.itemsize)
print(d.dtype.name, d.itemsize)
print(e.dtype.name, e.itemsize)
# array()函数默认根据列表或元素序列中各元素的数据类型,为ndarray对象指定最适合的数据类型。
# 也可以使用dtype选项作为array()的参数,明确指定dtype的类型。
# 如下定义一个复数数组
f = np.array([[1, 2, 3], [4, 5, 6]], dtype=complex)
print("-------------------------")
print(f)
int32 4
float64 8
str32 4
int32 4
int32 4
-------------------------
[[1.+0.j 2.+0.j 3.+0.j]
[4.+0.j 5.+0.j 6.+0.j]]
3.NumPy库自带的数组创建方法
# zeros()函数生成由shape参数指定维度信息,元素均为0的数组。
# 元素的数据类型为float64
g = np.zeros((3, 3))
print(g)
[[0. 0. 0.]
[0. 0. 0.]
[0. 0. 0.]]
# ones()函数与上述函数相似
# 元素的数据类型为float64
h = np.ones((3, 3))
print(h)
[[1. 1. 1.]
[1. 1. 1.]
[1. 1. 1.]]
# arange()函数,按特定规则生成包含一个数值序列的数组。
# arange(begin, end, step)
# 参数begin省略则从0开始
# 参数end应该比序列最后一个值大
# 参数step可以是浮点型
i = np.arange(0, 10)
j = np.arange(10)
k = np.arange(4, 10)
m = np.arange(0, 10, 2)
n = np.arange(0, 10, 1.3)
print(i)
print("-------------------------")
print(j)
print("-------------------------")
print(k)
print("-------------------------")
print(m)
print("-------------------------")
print(n)
[0 1 2 3 4 5 6 7 8 9]
-------------------------
[0 1 2 3 4 5 6 7 8 9]
-------------------------
[4 5 6 7 8 9]
-------------------------
[0 2 4 6 8]
-------------------------
[0. 1.3 2.6 3.9 5.2 6.5 7.8 9.1]
# 结合reshape()函数进行拆分
x1 = np.arange(0, 12).reshape(3, 4)
print(x1)
[[ 0 1 2 3]
[ 4 5 6 7]
[ 8 9 10 11]]
# linspace(begin, end, cnt)函数
# 第三个参数表示需要将begin和end范围分成几个部分
x2 = np.linspace(0, 10 , 6)
print(x2)
[ 0. 2. 4. 6. 8. 10.]
# random()函数以随机数填充数组
# 每次生成元素均会有所不同
x3 = np.random.random(3)
x4 = np.random.random((3, 3))
print(x3)
print("------------------------------------------")
print(x4)
[0.8223299 0.83657551 0.797519 ]
------------------------------------------
[[0.14562367 0.8657818 0.96508416]
[0.15094085 0.27332193 0.52784433]
[0.0260834 0.3047311 0.65182433]]
#eye(N)函数创建一个NxN单位矩阵(对角线为1,其余为0)
x5 = np.eye(4)
print(x5)
[[1. 0. 0. 0.]
[0. 1. 0. 0.]
[0. 0. 1. 0.]
[0. 0. 0. 1.]]
# 使用empty()函数返回全0数组的想法是不安全的
x6 = np.empty((2,3))
print(x6)
[[1. 2. 3.]
[4. 5. 6.]]
NumPy学习_00 ndarray的创建的更多相关文章
- NumPy学习_02 ndarray基本操作
1.算术运算符 它们只用于位置相同的元素之间,即为元素级的运算. 所得到的运算结果组成一个新的数组. 不用编写循环即可对数据执行批量运算.(矢量化) import numpy as np # 创建一个 ...
- NumPy学习_01 ndarray相关概念
1.NumPy库 NumPy = Numerical Python 是高性能科学计算和数据分析的基础库. pandas库充分借鉴了NumPy的相关概念,先行掌握NumPy库的用法,才能把pandas的 ...
- Python数据分析:Numpy学习笔记
Numpy学习笔记 ndarray多维数组 创建 import numpy as np np.array([1,2,3,4]) np.array([1,2,3,4,],[5,6,7,8]) np.ze ...
- Numpy学习之——数组创建
Numpy学习之--数组创建 过程展示 import numpy as np a = np.array([2,3,9]) a array([2, 3, 9]) a.dtype dtype('int32 ...
- 数据分析之Pandas和Numpy学习笔记(持续更新)<1>
pandas and numpy notebook 最近工作交接,整理电脑资料时看到了之前的基于Jupyter学习数据分析相关模块学习笔记.想着拿出来分享一下,可是Jupyter导出来h ...
- Python NumPy学习总结
一.NumPy简介 其官网是:http://www.numpy.org/ NumPy是Python语言的一个扩充程序库.支持高级大量的维度数组与矩阵运算,此外也针对数组运算提供大量的数学函数库.Num ...
- NumPy学习(让数据处理变简单)
NumPy学习(一) NumPy数组创建 NumPy数组属性 NumPy数学算术与算数运算 NumPy数组创建 NumPy 中定义的最重要的对象是称为 ndarray 的 N 维数组类型. 它描述相同 ...
- numpy 学习笔记
numpy 学习笔记 导入 numpy 包 import numpy as np 声明 ndarray 的几种方法 方法一,从list中创建 l = [[1,2,3], [4,5,6], [7,8,9 ...
- NumPy 从已有的数组创建数组
NumPy 从已有的数组创建数组 本章节我们将学习如何从已有的数组创建数组. numpy.asarray numpy.asarray 类似 numpy.array,但 numpy.asarray 只有 ...
随机推荐
- java1.8--OptionalInt,OptionalDouble,OptionalLong类
OptionalInt,OptionalDouble,OptionalLong类的工作方式与Optional类十分类似,只不过他们是专门操作int,都变了,long类型的值而设计的.因此,他们分别定义 ...
- maven系列--maven目录
我们在玩maven,首先就是利用maven来管理我们的项目.其实maven并不难,它无非是一种目录结构.所以在本系列开始之前,我们要细致的了解下maven的目录,其实也就是maven的约定. 约定优于 ...
- @@IDENTITY详细测试
今天看数据库SQL,有发现存储过程中有使用到SCOPE_IDENTITY()这个函数,后来问了下谷歌大婶,搜到一个比较重要的博客,链接如下:https://dotblogs.com.tw/kkman0 ...
- Spring 4.x (三)
1 Spring中加入DataSource并引入jdbc.properties 步骤: ①加入c3p0的jar包和mysql的驱动包 ②在src下新建jdbc.propertes文件 jdbc.dri ...
- 【转】 要做linux运维工程师的朋友,必须要掌握以下几个工具才行
本人是linux运维工程师,对这方面有点心得,现在我说说要掌握哪方面的工具吧 说到工具,在行外可以说是技能,在行内我们一般称为工具,就是运维必须要掌握的工具. 我就大概列出这几方面,这样入 ...
- MySQL --当AUTO_INCREMENT自增遇到0
熟悉SQL Server的DBA都知道,在SQL Server中如果想要显示制定自增值,除了在INSERT语句中显示写明自增列外,还需要使用SET IDENTITY_INSERT TB_NAME ON ...
- js中的深拷贝与浅拷贝
对象的深拷贝于浅拷贝 对于基本类型,浅拷贝过程就是对值的复制,这个过程会开辟出一个新的内存空间,将值复制到新的内存空间.而对于引用类型来书,浅拷贝过程就是对指针的复制,这个过程并没有开辟新的堆内存空间 ...
- JFinal源码 分析之 Core包分析
ActionHandler.java 这个类继承了上面 说的Handler类,首先我们 上 几个属性 ,下面几个 属性我们 需要 关心哪些东西 呢?首先 是ActionMapping和RenderMa ...
- python 之协程
协程: 协程,又称微线程. 是一种用户态的轻量级线程(存在一个线程中,所以没有上下文切换,与同步) 无需线程上下文切换的开销 在线程中,线程切换时需要记住上下文 无需原子操作及同步的开销 没有锁了, ...
- Jmeter Smock Test规范设计
Jmeter Smock Test规范设计 一.Smock Test物料 1.开发运行工具Jmeter,(下载地址: http://jmeter.apache.org/download_jmeter. ...