Python --NumPy库基础方法(1)

NumPy

Numpy(Numerical Python) 是科学计算基础库,提供大量科学计算相关功能,比如数据统计,随机数生成等。其提供最核心类型为多维数组类型(ndarray),支持大量的维度数组与矩阵运算,Numpy支持向量处理ndarray对象,提高程序运算速度。

安装

安装 NumPy 最简单的方法就是使用 pip 工具,语法格式如下:

pip install numpy
pip install jupyter notebook

在pycharm打开jupyter notebook:

打开pycharm中的命令端,输入jupyter notebook,等待一会会自动跳转,若是不跳转,点击最下面的链接:

在这里插入图片描述
在这里插入图片描述

跳转页面后,创建新的程序,我们使用jupyter学习Numpy。

Numpy运行方法:Shift键 + Enter键。如:

在这里插入图片描述

写好代码后直接按下两键。更多具体的jupyter notebook界面操作方法,自行查找详细操作。

array创建数组

numpy模块的array函数可以生成多维数组。语法格式如下:

numpy.array(object, dtype = None, copy =True, order = None, subok = False, ndmin = 0)

object :数组或嵌套的数列。 dtype :数组元素的数据类型,可选。 copy: 对象是否需要复制,可选

order :创建数组的样式,C为行方向,F为列方向,A为任意方向(默认)

subok :默认返回一个与基类类型一致的数组。 ndmin :指定生成数组的最小维度

创建一维

import numpy as np	#导包b=np.array([1,2,3,4,5,6])
print(b,b.shape)	#shape显示数组的维度
----------- 	#红线下为输出结果
[1 2 3 4 5 6] (6,)

创建二维

a = np.array([[1,2,3],[4,5,6],[7,8,9]])
print(a)
print("a数组的维度:",a.shape)
--------------------------
[[1 2 3][4 5 6][7 8 9]]
a数组的维度: (3, 3)

ndmin参数的使用

#ndmin参数:
a = np.array([1,2,3,4,5,6],ndmin = 3)	#指定生成数组的最小维度为3
print(a)
------------------
[[[1 2 3 4 5 6]]]

dtype参数的使用

#dtype参数:改变数组元素的数据类型
#将数组内的元素强制变成浮点型
a = np.array([1,2,3,4,5,6],dtype = np.float64)
print(a)
-----------------
[1. 2. 3. 4. 5. 6.]

arange创建数组

使用 arange 函数创建数值范围并返回 ndarray 对象,函数格式如下:

numpy.arange(start, stop, step, dtype)

start :起始值,默认为0。 stop: 终止值(不包含)。 step :步长,默认为1

dtype :返回ndarray的数据类型,如果没有提供,则会使用输入数据的类型。

#arange函数创建数值范围  
#格式:numpy.arange(start,stop,step,dtype)  取值:左闭右开#arange生成 0 到 5 的数组
x = np.arange(0,5,dtype=int)
print(x)
#-------------------------
#arange设置了起始值、终止值及步长
y = np.arange(10,20,2,dtype = np.float64)
print(y)
#--------------------
#创建二维数组
z = np.array([np.arange(1,4),np.arange(4,7),np.arange(7,10)])
print(z)

输出结果:

[0 1 2 3 4]
-------------------
[10. 12. 14. 16. 18.]
------------------------
[[1 2 3][4 5 6][7 8 9]]

随机数创建

numpy中的random模块包含了很多方法可以用来产生随机数。

随机数

#返回[0.0,1.0)范围的随机数
#格式:numpy.random.random(size=None) ---> size:表示数据长度维度x=np.random.random(size=4)
print(x)
----------------
[0.39089737 0.27449493 0.67038824 0.18743961]
y = np.random.random(size=(3,4))
print(y)
-----------------
[[0.46791494 0.55568935 0.89622367 0.47164053][0.01337248 0.02821914 0.4660383  0.74495001][0.96514074 0.0456898  0.11795308 0.99197463]]

随机整数

#返回整数
#格式:numpy.random.randint(low,high,size)x = np.random.randint(5,size=10)  #---> size:表示数据长度维度
print(x)
y = np.random.randint(5,10,size=(3,4))
print(y)
$----------------------------------------$
[0 3 3 4 4 0 0 0 3 0]
---------------------
[[6 7 9 6][6 9 8 6][6 5 9 6]]

正太分布

#正太分布  具有标准正太分布(期望0 方差1)
#格式:numpy.random.randn(d0,d1,d2,…,dn)
x = np.random.randn()
print(x)
------------------------
0.6666711910611633y = np.random.randn(2,4)
print(y)
---------------------
[[-0.11042552  0.03771884  0.70705774  0.49759948][-1.83386129  0.7898438  -0.76104361 -0.4511798 ]]z = np.random.randn(2,3,4)
print(z)
---------------------
[[[ 1.43434958  0.73995544  0.14880011  0.7429944 ][-0.51394552  0.84819023 -0.56734252  0.27952588][ 0.11325095 -1.35043481  0.18511292  0.67372189]][[ 1.74016415  0.890556    0.55970424  0.42848806][ 1.3033731   0.52913202 -0.07831286 -1.33728252][-0.36403971  0.9837446   0.87700483 -0.19645756]]]
#指定期望和方差的正太分布  ---->格式:np.random.normal(loc,scale,size)
print(np.random.normal(loc = 3,scale = 4,size = (2,2,3)))
------------------
[[[-0.38508127  8.72575577  4.77984012][ 5.28413947 11.29557292  5.42547076]][[ 2.86169592 -3.9155134   1.19362943][ 4.2279321  -2.54565136 -1.06140229]]]

ndarray对象

在这里插入图片描述

Numpy 最重要的一个特点是其 N 维数组对象 ndarray,它是一系列同类型数据的集合,以 0 下标为开始进行集合中元素的索引。

x1 = np.random.randint(10,size = 6)
x2 = np.random.randint(10,size = (3,4))
x3 = np.random.randn(3,4,5)
print("ndim:",x1.ndim,x2.ndim,x3.ndim)   #ndim表示查看维度 
结果:ndim: 1 2 3print("shape:",x1.shape,x2.shape,x3.shape)   #查看尺度,对于矩阵,n行n列
结果:shape: (6,) (3, 4) (3, 4, 5)print("dtype:",x1.dtype,x2.dtype,x3.dtype)     #查看类型
结果:dtype: int32 int32 float64print("size:",x1.size,x2.size,x3.size)     #元素的个数,相当于shape中n*m
结果:size: 6 12 60print("itemsize:",x1.itemsize,x2.itemsize,x3.itemsize)   #ndarray对象中每个元素的大小,以字节为单位
结果:itemsize: 4 4 8

zeros创建

创建指定大小的数组,数组元素以 0 来填充,格式如下:

numpy.zeros(shape, dtype = float, order ='C')
#zeros创建
#格式:numpy.zeros(shape,dtype = float,order = 'c')x = np.zeros(5)   #创建的全0矩阵,默认是浮点型的
print(x)
结果:[0. 0. 0. 0. 0.]#设置类型为整数
y = np.zeros((5,),dtype = int)
print(y)
结果:[0 0 0 0 0]#创建二维全0数组
z = np.zeros((2,2))
print(z)
结果:[[0. 0.][0. 0.]]

zeros_like

根据传入的数组形状创建全为0的数组。

#zeros_like:根据传入的数组形状创建全为0的数组
a = np.array([np.arange(1,5),np.arange(4,8)])
z = np.zeros_like(a)
print(z)
--------------
array([[0, 0, 0, 0],[0, 0, 0, 0]])

ones创建

创建指定形状的数组,数组元素以 1 来填充,格式如下:

numpy.ones(shape, dtype = None, order = 'C')
#ones创建   创建指定形状的数组,数组元素以1来填充
#格式:numpy.ones(shape,dtype = None,order = "c")x = np.ones(5)
print(x)
结果:array([1., 1., 1., 1., 1.])y = np.ones((2,3),dtype = int)
print(y)
结果:array([[1, 1, 1],[1, 1, 1]])

ones_like

z = np.ones_like([np.arange(4,8),np.arange(2,6)])
print(z)
-------------------------
array([[1, 1, 1, 1],[1, 1, 1, 1]])

empty创建

创建一个指定形状(shape)、数据类型(dtype)且未初始化的数组,里面的元素的值是之前内存的值,格式如下:

numpy.empty(shape, dtype = float, order ='C')
#empty创建   创建一个指定形状、数据类型的数组,里面的元素值是之前内存里的,会变的
#格式:numpy.empty(shape,dtype = float,order = "c")x = np.empty([3,2],dtype = int)
print(x)
--------------------
array([[      3442,     946688],[ 184156160, 1936288828],[1836016500,   30817904]])

empty_like

y = np.empty_like([np.arange(1,5),np.arange(4,8)])
print(y)
-------------------------
array([[1136351920,        567,          0,          0],[         0,          0,          0,          0]])

empty创建数组的使用

#empty创建数组的使用x = np.arange(5)
y = np.empty(10,dtype = int)
np.add(2,x,out=y[:5])  #将x的值追加2,赋给y的前五个值   未被接收,可以直接打印出结果
-----------------------------
array([2, 3, 4, 5, 6])

full()创建

创建全为某个指定值的数组,格式如下:

full(shape,fill_value)
# full的创建  创建全为某个指定值的数组
#格式:full(shape,fill_value)a = np.full((2,2),3)   #创建一个2*2的矩阵,里面全为3
print(a)
----------------
array([[3, 3],[3, 3]])

full_like

#full_like
b = np.full_like(([np.arange(1,5),np.arange(4,8)]),4)
print(b)
------------------------
array([[4, 4, 4, 4],[4, 4, 4, 4]])

创建单位矩阵

单位矩阵从左上角到右下角的对角线上的元素均为1,除此以外全都为0。任何矩阵与单位矩阵相乘都等于本身,而且单位矩阵因此独特性在高等数学中也有广泛应用。创建单位矩阵的两种方法:eye 和identity方法

eye方法

n1 = np.eye(3,dtype = int)
print(n1)
-----------------------------
array([[1, 0, 0],[0, 1, 0],[0, 0, 1]])

identity方法

n2 = np.identity(3,dtype = int)
print(n2)
-------------------
array([[1, 0, 0],[0, 1, 0],[0, 0, 1]])

linspace创建

linspace函数用于创建一个一维数组,数组是一个等差数列构成的,格式如下:

np.linspace(start, stop, num=50,endpoint=True, retstep=False, dtype=None)

start:序列的起始值。

stop:序列的终止值,如果endpoint为true,该值包含于数列中。

num:要生成的等步长的样本数量,默认为50。

endpoint:该值为 ture 时,数列中中包含stop值,反之不包含,默认是True。

retstep:如果为 True 时,生成的数组中会显示间距,反之不显示。

dtype:ndarray 的数据类型

#linspace创建---->等差数列
#格式:np.linspace(start,stop,num = 50,endpoint=True,retstep=Flase,dtype=None)
#endpoint=True时----->[start,end],  否则[start,end)x = np.linspace(1,10,5)   #表示1-10的范围内,等差出5个数字
print(x)
结果:array([ 1.  ,  3.25,  5.5 ,  7.75, 10.  ])y = np.linspace(1,10,5,endpoint=False)   #endpoint=False,最后一位取不到10,不能以10结尾
print(y)
结果:array([1. , 2.8, 4.6, 6.4, 8.2])#retstep显示等差间隔:
z = np.linspace(10,20,5,retstep=True)
print(z)
结果:(array([10. , 12.5, 15. , 17.5, 20. ]), 2.5)

logspace创建

logspace 函数用于创建一个于等比数列。格式如下:

np.logspace(start, stop, num=50,endpoint=True, base=10.0, dtype=None)

start:序列的起始值为:base ** start

stop:序列的终止值为:base ** stop。如果endpoint为true,该值包含于数列中

num:要生成的等步长的样本数量,默认为50

endpoint:该值为 ture 时,数列中中包含stop值,反之不包含,默认是True。

base:对数 log 的底数。

dtype:ndarray 的数据类型

#logspace创建----->等比数列
#格式:np.logspace(start,stop,num = 50,endpoint=True,base=10.0,dtype=None)x = np.logspace(0,9,10,base = 2)   #底数为2
print(x)
结果:array([  1.,   2.,   4.,   8.,  16.,  32.,  64., 128., 256., 512.])y = np.logspace(0,3,num = 4)   #默认底数为10
print(y)
结果:array([   1.,   10.,  100., 1000.])

总结

本篇介绍了一部分Numpy库中的方法,Numpy库很大很丰富,务必整理牢记,对接下来的学习很重要。

还有部分方法下期介绍哦~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3267492.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

mysql语法介绍

MySQL 语法主要基于 SQL(Structured Query Language)标准,用于管理和操作关系型数据库。以下是一些基本的 MySQL 语句: 1.创建数据库: CREATE DATABASE database_name; 1.选择数据库: USE database_name;…

科研绘图系列:R语言组合堆积图(stacked barplot with multiple groups)

介绍 通常堆积图的X轴表示样本,样本可能会存在较多的分组信息,通过组合堆积图和样本标签分组信息,我们可以得到一张能展示更多信息的可发表图形。 加载R包 knitr::opts_chunk$set(warning = F, message = F) library(tidyverse) library(cowplot) library(patchwork)导入…

springcloud RocketMQ 客户端是怎么走到消费业务逻辑的 - debug step by step

springcloud RocketMQ ,一个mq消息发送后,客户端是怎么一步步拿到消息去消费的?我们要从代码层面探究这个问题。 找的流程图,有待考究。 以下我们开始debug: 拉取数据的线程: PullMessageService.java 本…

云盘高速视觉检测机,如何提高螺丝件的检测效率?

螺纹螺丝钉是一种常见的螺纹结构紧固件,通常由金属制成,具有螺旋状的螺纹结构。这种螺丝钉旨在通过旋入螺纹孔或材料中,实现可靠的固定连接。 螺纹螺丝钉具有螺旋状的螺纹结构,使其能够轻松旋入金属或其他硬质材料。主要用于金属…

UDP的报文结构及其注意事项

1. 概述 UDP(User Datagram Protocol)是一种无连接的传输层协议,它提供了一种简单的数据传输服务,不保证数据的可靠传输。在网络通信中,UDP通常用于一些对实时性要求较高、数据量较小、传输延迟较低的应用&#xff0c…

NLP基础知识2【各种大模型的注意力】

注意力 传统Attention存在的问题优化方向变体有哪些现在的主要变体集中在KVMulti-Query AttentionGrouped-query AttentionFlashAttention 传统Attention存在的问题 上下文约束速度慢,显存占用大(因为注意力考虑整体信息,所以每一个位置都要…

【大模型】基于LoRA微调Gemma大模型(1)

文章目录 一、LoRA工作原理1.1 基本原理1.2 实现步骤 二、LoRA 实现2.1 PEFT库:高效参数微调LoraConfig类:配置参数 2.2 TRL库SFTTrainer 类 三、代码实现3.1 核心代码3.2 完整代码 参考资料 大模型微调技术有很多,如P-Tuning、LoRA 等&#…

狗都能看懂的Actor-Critic强化学习算法讲解

Review Policy Gradient 上面的公式是Policy Gradient的更新函数,这个式子是指在 s t s_t st​时刻采取了 a t a_t at​,计算出对应发生的概率 p θ p_\theta pθ​,然后计算在采取了这个 a t a_t at​之后,所得到的reward有多大。…

table car vs. table cars:数据库命名用单数还是复数?

数据库的命名方式已经形成了许多共识,比如全部小写、下划线分隔、使用标准缩写等;其中就包括「使用单数名词」。 用户 jonr 在 reddit 网的程序员笑话(ProgrammerHumor)社区发了一篇帖子,调侃这些数据库命名方式的共识…

Hive3:基本介绍

一、概述 Apache Hive是一款分布式SQL计算的工具, 其主要功能是: 将SQL语句翻译成MapReduce程序运行 二、基本逻辑简介 主要由两大模块组成:元数据管理,SQL解析器 1、元数据管理 即:数据位置信息、数据结构信息、…

在jmeter中使用javascript脚本

工作上遇到一个压力测试的需求,需要测试几个考试相关的接口。其中有一个获取试题详情的接口,和一个提交答题信息的接口。后一个接口以上一接口的返回内容为参数,添加上用户的答案即可。jmeter提供了非常多的方式可以实现该需求,这…

Multi Range Read与Covering Index是如何优化回表的?

上篇文章末尾我们提出一个问题:有没有什么办法可以尽量避免回表或让回表的开销变小呢? 本篇文章围绕这个问题提出解决方案,一起来看看MySQL是如何优化的 回表 为什么会发生回表? 因为使用的索引并没有整条记录的所有信息&…

Vue3 Pinia/组件通信

2. pinaia 符合直觉的Vue.js状态管理库 集中式状态(数据)管理 官网 2.1 搭建pinaia环境 第一步:npm install pinia 第二步:操作src/main.ts import { createApp } from vue import App from ./App.vue/* 引入createPinia&…

案例分析:人工智能在航空航天领域的应用

作者主页: 知孤云出岫 目录 作者主页:案例分析:人工智能在航空航天领域的应用引言人工智能在航空航天中的主要应用案例分析案例一:AI优化航天器设计案例二:AI辅助飞行安全——预测维护案例三:AI自动驾驶系统案例四:A…

关键词查找【Boyer-Moore 算法】

1、【Boyer-Moore 算法】 【算法】哪种算法有分数复杂度?- BoyerMoore字符串匹配_哔哩哔哩_bilibili BM算法的精华就在于BM(text, pattern),也就是BM算法当不匹配的时候一次性可以跳过不止一个字符。即它不需要对被搜索的字符串中的字符进行逐一比较,而…

探索算法系列 - 滑动窗口

目录 长度最小的子数组(原题链接) 无重复字符的最长子串(原题链接) 最大连续1的个数 III(原题链接) 将 x 减到 0 的最小操作数(原题链接) 水果成篮(原题链接&#x…

第六章:支持向量机

目录 6.1 间隔与支持向量 6.2 对偶问题 6.3 核函数 6.4 软间隔与正则化 6.4.1 软间隔 6.4.2 正则化 6.5 支持向量回归 6.6 核方法 6.1 间隔与支持向量 分类学习最基本的想法就是基于训练集D在样本空间中找到一个划分超平面,将不同类别的样本分开.但能将训练样本分开的…

【宝藏系列】模/数转换十大常用滤波算法

【宝藏系列】模/数转换十大常用滤波算法 文章目录 【宝藏系列】模/数转换十大常用滤波算法👨‍🏫ADC(Analog-to-Digital Converter,模数转换器)1️⃣限幅滤波法2️⃣中位值滤波法3️⃣算术平均滤波法4️⃣递推平均滤波…

PLC通过IGT-SER系列智能网关快速实现WebService接口调用案例

IGT-SER系列智能网关支持PLC设备数据对接到各种系统平台,包括SQL数据库,以及MQTT、HTTP协议的数据服务端;通过其边缘计算功能和脚本生成的工具软件,非常方便快速实现PLC、智能仪表与WebService服务端通信。 本文是通过智能网关读取…

Ubuntu 22.04.4 LTS (linux) GoAccess 分析 Nginx 日志

1 安装goaccess sudo apt-get update sudo apt-get install goaccess 2 控制台运行 goaccess -a -d -f /usr/local/openresty/nginx/logs/access.log -p /etc/goaccess/goaccess.conf #sudo vim /etc/goaccess/goaccess.conf time-format %H:%M:%S date-format %d/%b…