Numpy简易入门

1.1 认识Numpy数组对象

1.1.1 导入NumPy工具包
#导包并起别名为np
import numpy as np
1.1.2 创建一个三行五列的数组
data = np.arange(15).reshap(3, 5)

打印结果:data

1.1.3 查询data类型
print(type(data))

打印结果:

<class 'numpy.ndarray'>
ndarray是一个N维数组类型的对象
1.1.4 查询数组维度的个数
print(data.ndim)

输出结果:

2
1.1.5 查询数组的形状
print(data.shape)

输出结果

(3, 5)
1.1.6 查询数组元素的个数
print(data.size)

输出结果

15
1.1.7 查询数组中元素的类型
print(data.dtype)

输出结果

int32

1.2 创建Numpy数组

1.2.1 创建一个一维数组并赋值
import numpy as np
data1 = np.array([1, 2, 3])
print(data1)

输出结果

[1 2 3]
1.2.2 创建一个二维数组并赋值
data2 = np.array([[1, 5, 1], [2, 4, 7]])

打印结果

[[1 5 1][2 4 7]]
1.2.3 创建一个全零数组
#默认为浮点型
data3 = np.zeros((3, 4))
#改为整型
data3 = np.zeros((3, 4), int)

输出结果

//默认
[[0. 0. 0. 0.]
[0. 0. 0. 0.]
[0. 0. 0. 0.]]
//整型
[[0 0 0 0]
[0 0 0 0]
[0 0 0 0]]
1.2.4 创建一个全1数组
data4 = np.ones((3, 4))

输出结果

[[1. 1. 1. 1.][1. 1. 1. 1.][1. 1. 1. 1.]]
1.2.5 创建一个全空数组
#其实是趋于0的数
data5 = np.empty((3, 4))

输出结果

[[1.06810268e-306 1.42419938e-306]
[7.56603881e-307 7.56600486e-307]
[1.02360867e-306 1.29061889e-306]
[6.23040373e-307 1.42419530e-306]
[1.60219035e-306 3.11529184e-307]]
1.2.6 以等差数列创建一个数组
#从1开始到20为止,步长为5
data6 = np.arange(1, 20, 5)

输出结果

[ 1  6 11 16]
1.2.7 创建一个浮点类型的数组
data7 = np.array([1, 2, 3, 0.1], float)

输出结果

[1.  2.  3.  0.1]

其他的也可以指定类型,比如:

data8 = np.ones((2, 3), dtype='float64')
#也可以这样写
#data8 = np.ones((2, 3), float)

输出结果

[[1. 1. 1.][1. 1. 1.]]

1.3 ndarry对象的数据类型

1.3.1 查看数据类型
data1 = np.array([[1, 2, 3], [4, 5, 6]])
print(data1.dtype.name)

输出结果

int32
1.3.2 转换数据类型
data2 = data1.astype(np.float64)
print(data2.dtype)data3 = np.array([1.2, 1.3, 1.4, 3.3])
data4 = data3.astype(np.int64)
print(data4.dtype)data5 = np.array(["1", "2", "3", '4'])
data6 = data5.astype(np.int64)
print(data6)
print(data6.dtype)

输出结果

float64
int64
[1 2 3 4]
int64

1.4 数组运算

1.4.1 向量化运算
import numpy as npdata1 = np.array([[1, 2, 3], [4, 5, 6]])
data2 = np.array([[-1, -4, 1], [7, 5, 2]])
#将第一个数组中的元素与第二个数组中对应的元素进行加减乘除
print(data1 + data2)
print(data1 - data2)
print(data1 * data2) 
print(data1 / data2)

输出结果

[[ 0 -2  4][11 10  8]][[ 2  6  2][-3  0  4]][[-1 -8  3][28 25 12]][[-1.         -0.5         3.        ][ 0.57142857  1.          3.        ]]
1.4.2 数组广播

数组间的基础运算是一对一,但是当两者不一样时。就会自动触发广播机制,
但有些无法扩展的会报错,比如:(行数,列数), (3, 2) + (1, 3)报错

data3 = np.array([[1], [2], [3], [4]])
data4 = np.array([1, 2, 3])
print(data3 + data4)

输出结果

//相当于
1 1 1      1 2 3
2 2 2  +   1 2 3 
3 3 3      1 2 3
4 4 4      1 2 3[[2 3 4][3 4 5][4 5 6][5 6 7]]
1.4.3 数组与标量间的运算

将数组中每个元素与标量计算,返回计算后的数组

data8 = np.array([[2, 8, 4], [3, 5, 7], [2, 4, 9]])
x = 7
print(data8 + x)
print(x - data8)
print(data8 * x)
print(x / data8)

输出结果

[[ 9 15 11][10 12 14][ 9 11 16]]
[[ 5 -1  3][ 4  2  0][ 5  3 -2]]
[[14 56 28][21 35 49][14 28 63]]
[[3.5        0.875      1.75      ][2.33333333 1.4        1.        ][3.5        1.75       0.77777778]]

1.5 ndarray的索引和切片

1.5.1 整数索引和切片的基本使用
import numpy as npdata = np.arange(36).reshape(6, 6)
print(data)
# 打印第五行
print(data[5])
# 打印第3 ~ 5-1 行
print(data[3:5])
# 打印第0行,从第3到4的元素
print(data[0, 3:5])
# 打印第1行,从0到1的元素
print(data[1, :2])
# 打印第0行,从1到6-1步长为2
print(data[0, 1:6:2])
# 打印第2行第3个元素
print(data[2, 3])
# 打印前两行
print(data[:2])
# 打印第1到3行,第1到3列
print(data[1:3, 1:3])

输出结果

[[ 0  1  2  3  4  5][ 6  7  8  9 10 11][12 13 14 15 16 17][18 19 20 21 22 23][24 25 26 27 28 29][30 31 32 33 34 35]][30 31 32 33 34 35]
[[18 19 20 21 22 23][24 25 26 27 28 29]][3 4][1 3 5]15
[[ 0  1  2  3  4  5][ 6  7  8  9 10 11]][[ 7  8][13 14]][6 7]
1.5.2 花式(数组)索引的基本使用
arr = np.empty((4, 4))
for i in range(4):arr[i] = np.arange(i, i+4)
print(arr)
# 打印第0和2行
print(arr[[0, 2]])
# 获取(1, 0)和(3, 2)
print(arr[[1, 3], [0, 2]])

输出结果

[[0. 1. 2. 3.][1. 2. 3. 4.][2. 3. 4. 5.][3. 4. 5. 6.]][[0. 1. 2. 3.][2. 3. 4. 5.]][1. 5.]
1.5.3 布尔型
studentName = np.array(["Tom", "Amiya", "Theresa"])
studentScore = np.array([[79, 88, 89], [87, 65, 95], [74, 85, 61]])
print(studentName == "Amiya")
print(studentScore[studentName == "Amiya"])
print(studentScore[studentName == 'Theresa', :1])

输出结果

[False  True False]
[[87 65 95]]
[[74]]

1.6 数组的转置和轴对称

arr = np.arange(12).reshape(3, 4)
print(arr)
# 使用T属性对arr转置
print(arr.T)
# 转置,0为x,1为y, 设置为1,0,代表xy互换
print(arr.transpose(1, 0))arr1 = np.arange(12).reshape(2, 2, 3)
print(arr1)
# 将xy互换
print(arr1.transpose(1, 0, 2))
# swapaxes是将n维数组中两个维度进行调换,xy互换
print(arr1.swapaxes(1, 0))

输出结果

[[ 0  1  2  3][ 4  5  6  7][ 8  9 10 11]]
------------------
[[ 0  4  8]
[ 1  5  9]
[ 2  6 10]
[ 3  7 11]]------------------
[[ 0  4  8][ 1  5  9][ 2  6 10][ 3  7 11]]------------------
[[[ 0  1  2][ 3  4  5]][[ 6  7  8][ 9 10 11]]]------------------
[[[ 0  1  2][ 6  7  8]][[ 3  4  5][ 9 10 11]]]------------------
[[[ 0  1  2][ 6  7  8]][[ 3  4  5][ 9 10 11]]]

1.7 numpy通用数组

import numpy as nparr1 = np.array([4, 8, 4, 2])
# 开方
print(np.sqrt(arr1))
# 取绝对值
arr2 = np.array([-1, 2, -10, -2])
print(np.abs(arr2))
# 求平方
print(np.square(arr2))
# 计算arr1和arr2的和
print(np.add(arr1, arr2))
# 计算两个数组的乘积
print(np.multiply(arr1, arr2))
# 多个数组取最大值
print(np.maximum(arr1, arr2))
# 执行元素级的比较操作
print(np.greater(arr1, arr2))
print(np.less(arr1, arr2))

输出结果

[2.         2.82842712 2.         1.41421356]
[ 1  2 10  2]
[  1   4 100   4]
[ 3 10 -6  0]
[ -4  16 -40  -4]
[4 8 4 2]
[ True  True  True  True]
[False False False False]

1.8 利用numpy数组进行数据处理

1.8.1 将条件逻辑转为数组运算
# true选第一个,false选第二个
arr1 = np.array([1, 2, 5])
arr2 = np.array([4, 7, 1])
con = np.array([True, False, False])
print(np.where(con, arr1, arr2))

输出结果

[1 7 1]
1.8.2 数组统计运算
arr = np.array([1, 2, -1, 7])
# 求和
print(arr.sum())
# 求平均值
print(arr.mean())
# 求最小值
print(arr.min())
# 求最大值
print(arr.max())
# 求最小值的索引
print(arr.argmin())
# 求最大值的索引
print(arr.argmax())
# 计算元素的累计和
print(arr.cumsum())
# 计算元素的累计积
print(arr.cumprod())
# np.diff()数组中后一个数减前一个数
# np.diff(a, n=1, axis=-1, prepend=<no value>, append=<no value>)[source]
# a: 数组, n:计算次数,axis: 0竖直减、1横着减
print(np.diff(arr))a = np.array([-0.7, 1.2, -1.2, 0.5])
# 向下取整
print(np.floor(a))
#向上取整
print(np.ceil(a))
# 实现大于0取原值,小于0取零
print(np.where(a>0, a, 0))

输出结果

9
2.25
-1
7
2
3
[1 3 2 9]
[  1   2  -2 -14]
[ 1 -3  8]
[-1.  1. -2.  0.]
[-0.  2. -1.  1.]
[0.  1.2 0.  0.5]
数组排序
arr = np.array([[2, 1, 8], [8, 4, 1], [3, 9, 4]])
# 按行排序排序
arr.sort()
print(arr)

输出结果

[[1 2 8][1 4 8][3 4 9]]
arr = np.array([[2, 1, 8], [8, 4, 1], [3, 9, 4]])
# 按列排序
arr.sort(0)
print(arr)

输出结果

[[2 1 1][3 4 4][8 9 8]]
1.8.4 检索数组元素
# 检查是否有大于0的数
print(np.any(arr > 0))
# 检查是否所有元素都大于0
print(np.all(arr > 0))
1.8.5 唯一化及其他集合逻辑
a = np.array([1, 2, 4, 5, 1, 2, 4])
# 去重
print(np.unique(a))
# 输出序列a中元素与序列[1,5]是否相同
print(np.in1d(a, [1, 5]))

输出结果

[1 2 4 5]
[ True False False  True  True False False]

1.9 线性代数模块

# 矩阵乘法
arr1 = np.array([[1, 2, 3], [1, 2, 3]])
arr2 = np.array([[1, 2], [2, 2], [4, 1]])
print(arr1.dot(arr2))
print(np.dot(arr1, arr2))

输出结果

[[17  9][17  9]]
[[17  9][17  9]]

1.10 随机数模块

# 生成3x3的随机矩阵,值从0到1
print(np.random.rand(3, 3))
# 生成三维随机矩阵
print(np.random.rand(3, 3, 2))
# 设置种子
np.random.seed(0)
# 产生随机数
print(np.random.rand(5))
np.random.seed()
print(np.random.rand(5))

输出结果

[[0.91915309 0.3273642  0.48099848][0.30841312 0.5656747  0.98334858][0.29554889 0.18315713 0.47518993]][[[0.75420241 0.30841421][0.68911038 0.05800794][0.02904897 0.37479255]][[0.37839904 0.3322166 ][0.22317202 0.18784184][0.47441706 0.0337881 ]][[0.48213152 0.71993534][0.52116272 0.92980627][0.30824145 0.19018865]]][0.5488135  0.71518937 0.60276338 0.54488318 0.4236548 ][0.73906657 0.14488605 0.63462347 0.46018479 0.98655736]

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java中的Spliterator与并行计算

在Java编程中&#xff0c;Spliterator是一个强大的接口&#xff0c;它为集合和数组等数据结构提供了并行处理的能力。Spliterator的设计目标是支持高效并行遍历&#xff0c;同时兼容传统的迭代器模式。本文将详细介绍Spliterator的使用方法&#xff0c;并通过实例展示其在并行计…

Jenkins 新建配置 Freestyle project 任务 六

Jenkins 新建配置 Freestyle project 任务 六 一、新建任务 在 Jenkins 界面 点击 New Item 点击 Apply 点击 Save 回到任务主界面 二、General 点击左侧 Configure Description&#xff1a;任务描述 勾选 Discard old builds Discard old builds&#xff1a;控制何时…

Linux CentOS 7部署Vulhub靶场

漏洞复现环境&#xff1a; 1、Linux操作系统中通过Docker部署的Vulhub靶场&#xff1a; docker docker-compose 2、Nmap扫描工具 一、部署靶场 1、安装Docker 1、下载docker yum install docker 安装完成&#xff0c;如下图&#xff1a; 2、开启docker服务 [rootlocalhost…

DeepSeek笔记(二):DeepSeek局域网访问

如果有多台电脑&#xff0c;可以通过远程访问&#xff0c;实现在局域网环境下多台电脑共享使用DeepSeek模型。在本笔记中&#xff0c;首先介绍设置局域网多台电脑访问DeepSeek-R1模型。 一、启动Ollama局域网访问 1.配置环境变量 此处本人的操作系统是Windows11&#xff0c;…

软件测试技术之跨平台的移动端UI自动化测试(上)

摘要&#xff1a;本文提出一种跨平台的UI自动化测试方案&#xff0c;一方面使用像素级的截图对比技术&#xff0c;解决传统UI自动化测试难以验证页面样式的问题&#xff1b;另一方面用统一部署在服务器端的JavaScript测试代码代替Android和iOS测试代码&#xff0c;大大提高编写…

MySQL深度剖析-InnoDB索引与B+树

1. 什么是B树&#xff1f; B 树是一种自平衡的多叉树&#xff0c;它是 B 树的一种变体。与 B 树不同&#xff0c;B 树的所有数据都存储在叶子节点&#xff0c;非叶子节点仅存储索引&#xff0c;且叶子节点之间通过双向链表相连。这种结构使得 B 树在范围查询和排序操作上具…

win11系统 Docker Desktop提示Docker Engine stopped解决全过程记录

DockerDesktop安装指南以及Windows下WSL2和 Hyper-V相关问题追查 【已解决】win10系统 Docker 提示Docker Engine stopped解决全过程记录 本篇文章主要记录Docker Desktop安装和使用时出现的问题及解决方法&#xff0c;以及后续使用夜神模拟器&#xff0c;关闭了Hyper-V时&am…

如何使用UniApp实现页面跳转和数据传递?

在 UniApp 中&#xff0c;页面跳转和数据传递是基本的功能&#xff0c;允许用户在应用中浏览不同的页面并传递必要的信息。以下是如何实现页面跳转和数据传递的详细步骤和示例。 一、页面跳转 UniApp 提供了几种方式来进行页面跳转&#xff0c;主要包括&#xff1a; uni.nav…

VSCode配合cline实现自动编程

VS Code是微软开发的代码编辑器&#xff0c;可以配合安装不同的插件&#xff0c;支持对不同语言、项目类型的开发。 &#xff08;1&#xff09;安装cline插件&#xff1a;在vscode扩展商店搜索cline&#xff0c;并安装&#xff1b; &#xff08;2&#xff09;选择不同的大模型…

Docker 镜像标签使用

写在前面 当使用命令 docker pull mysql 拉取镜像时&#xff0c;其实等价于如下命令 docker pull mysql:latest latest 是默认的标签&#xff0c;字面上理解为最新版本的镜像&#xff0c;实质上 latest 只是镜像的标签名称&#xff0c;跟具体某个版本号地位一样&#xff0c;…

CHARMM-GUI EnzyDocker: 一个基于网络的用于酶中多个反应状态的蛋白质 - 配体对接的计算平台

❝ "CHARMM-GUI EnzyDocker for Protein−Ligand Docking of Multiple Reactive States along a Reaction Coordinate in Enzymes"介绍了 CHARMM-GUI EnzyDocker&#xff0c;这是一个基于网络的计算平台&#xff0c;旨在简化和加速 EnzyDock 对接模拟的设置过程&…

mysql 使用 CONCAT、GROUP_CONCAT 嵌套查询出 json 格式数据

tb_factory表由 factory_code 和 factory_name 字段&#xff0c;查询出如下所示效果&#xff1a; {"factory_0001": "工厂1","factory_0002": "工厂2",... } select sql&#xff1a; SELECT CONCAT( "{",GROUP_CONCAT( C…

Docker__持续更新......

Docker 1. 基本知识1.1 为什么有Docker?1.2 Docker架构与容器化 画图解释 画图解释2. 项目实战 1. 基本知识 1.1 为什么有Docker? 用一行命令跨平台安装项目&#xff0c;在不同平台上运行项目。把项目打包分享运行应用。 1.2 Docker架构与容器化 准备机器&#xff0c;在机…

解决 `pip is configured with locations that require TLS/SSL` 错误

问题描述 在使用 pip 安装 Python 包时&#xff0c;可能会遇到以下错误&#xff1a; WARNING: pip is configured with locations that require TLS/SSL, however the ssl module in Python is not available.这意味着 Python 的 ssl 模块未正确安装或配置&#xff0c;导致 p…

网络安全不分家 网络安全不涉及什么

何为网络安全 信息安全是指系统的硬件、软件及其信息受到保护&#xff0c;并持续正常运行和服务。信息安全的实质是保护信息系统和信息资源免受各种威胁、干扰和破坏&#xff0c;即保证信息的安全性。 网络安全是指利用网络技术、管理和控制等措施&#xff0c;保证网络系统和…

动手学Agent——Day2

文章目录 一、用 Llama-index 创建 Agent1. 测试模型2. 自定义一个接口类3. 使用 ReActAgent & FunctionTool 构建 Agent 二、数据库对话 Agent1. SQLite 数据库1.1 创建数据库 & 连接1.2 创建、插入、查询、更新、删除数据1.3 关闭连接建立数据库 2. ollama3. 配置对话…

android 的抓包工具

charles 抓包工具 官网地址 nullCharles Web Debugging Proxy - Official Sitehttps://www.charlesproxy.com/使用手册一定记得看官网 SSL Certificates • Charles Web Debugging Proxy http请求&#xff1a; 1.启动代理&#xff1a; 2.设置设备端口 3.手机连接当前代理 …

DeepSeek从入门到精通(清华大学)

​ DeepSeek是一款融合自然语言处理与深度学习技术的全能型AI助手&#xff0c;具备知识问答、数据分析、编程辅助、创意生成等多项核心能力。作为多模态智能系统&#xff0c;它不仅支持文本交互&#xff0c;还可处理文件、图像、代码等多种格式输入&#xff0c;其知识库更新至2…

数据结构:栈(Stack)及其实现

栈&#xff08;Stack&#xff09;是计算机科学中常用的一种数据结构&#xff0c;它遵循先进后出&#xff08;Last In, First Out&#xff0c;LIFO&#xff09;的原则。也就是说&#xff0c;栈中的元素只能从栈顶进行访问&#xff0c;最后放入栈中的元素最先被取出。栈在很多应用…

pdf-extract-kit paddle paddleocr pdf2markdown.py(效果不佳)

GitHub - opendatalab/PDF-Extract-Kit: A Comprehensive Toolkit for High-Quality PDF Content Extraction https://github.com/opendatalab/PDF-Extract-Kit pdf2markdown.py 运行遇到的问题&#xff1a; 错误&#xff1a; -------------------------------------- C Tra…