百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

入门numpy(50%-65%)「解读numpy官方文档」

suiw9 2024-10-23 18:49 32 浏览 0 评论

前言

这几天很忙啊,所以也没时间静下心来写文章,现在好点了,我们继续numpy官网之旅

import numpy as np

形状操作

改变数组的形状

a = np.floor(10*np.random.random((3,4)))a

a.resize((2,6))a

注:改变a数组形状

如果在改变形状操作中将尺寸给定为-1,则会自动计算其尺寸:

a.reshape(3,-1)

查看这部分更多更详细的用法可以看:https://docs.scipy.org/doc/numpy-dev/user/quickstart.html

下图部分:

堆叠不同的数组

几个数组可以沿不同的轴堆叠在一起:

a = np.floor(10*np.random.random((2,2)))a

b = np.floor(10*np.random.random((2,2)))b

np.vstack((a,b))

注:这里v是vertical的缩写,意思是垂直方向,所以这里是按照竖直方向堆叠数组

 np.hstack((a,b))

注:这里的h是horizontal的缩写,是水平方向,所以这里是指的水平方向堆叠数组

函数column_stack将1维数组作为列堆叠成2维数组。

from numpy import newaxisnp.column_stack((a,b))

注:水平方向堆叠成二维数组

a = np.array([4.,2.])b = np.array([2.,8.])a[:,newaxis]

注:切片出二维数组

np.column_stack((a[:,newaxis],b[:,newaxis]))

注:将两个切片的二维数组组成新的二维数组

np.vstack((a[:,newaxis],b[:,newaxis]))

注:竖直方向堆叠出新的二维数组

注意:在复杂情况下,r_和c_对于通过沿一个轴堆叠数字来创建数组很有用。 它们允许使用范围文字(“:”)

np.r_[1:4,0,4]

注:1—3,0,4组成数组

当使用数组作为参数时,r_和c_在其默认行为中类似于vstack和hstack,但允许使用可选参数来指定要连接的轴数。

查看这部分更多更详细的用法可以看:https://docs.scipy.org/doc/numpy-dev/user/quickstart.html

下图部分:

将一个数组分成几个较小的数组

使用hsplit,可以沿着水平轴拆分数组,方法是指定要返回的等同形状数组的数量,或者指定之后应该进行拆分的列

a = np.floor(10*np.random.random((2,12)))a

np.hsplit(a,3)

注:将a数组水平方向切分成相等的3份

np.hsplit(a,(3,4))

注:从第三个和第四个后面分别切一刀,水平分成3块新数组

np.hsplit(a,(3,))

注:从第三个后面切一刀,水平分成2块新数组

vsplit沿垂直轴分割,而array_split允许用来指定要分割的轴:

np.vsplit(a,(1,))

注:从第一行后面切一刀,垂直分成2块新数组

复制和视图

当操作数组时,它们的数据有时被复制到一个新的数组中,有时候不会。 这往往是初学者混乱的根源。 有三种情况:

没有复制的情况

简单的赋值不会使数组对象或其数据被复制

a = np.arange(12)b = a b is a

注:这里a和b指向的是同一个数组,操作时并没有产生新的复制内容

b.shape = 3,4a.shape

注:这里改变b数组的形状,a的也发生了变化,说明这里a和b指向的是同一个数组

Python将可变对象作为引用传递,因此函数调用不会复制一份新的

def f(x): print(id(x)) id(a)

f(a)

注:这里函数返回的结果id是相同的,所以函数调用不会复制一份新的内容(id是对象的唯一标识)

视图或浅拷贝

不同的数组对象可以共享相同的数据。 视图方法创建一个包含相同数据的新数组对象

c = a.view()c is a

注:通过view方法生成的c已经和a不是同一个了

c.base is a

注:c是基于a的

c.flags.owndata

注:c拥有数据?:并没有(因为c是拷贝了a的)

a.flags.owndata

注:a拥有数据

c.shape = 2,6

注:c的形状(3行4列)

c[0,4] = 1234
a

注:在c中修改会传到a中,因为数据实际保存在a中

切换数组返回其视图:

s = a[ : , 1:3] s[:] = 10 a

注:s[:]是s的视图。注意s=10 和 s[:]=10的不同

深层复制

深层复制方法将完整复制数组及其数据

d = a.copy() d is a

注:创建了新的数组和新的数据

d.base is a

注:d没有和a共享任何数据

d[0,0] = 9999a

注:d内容修改不会影响a

函数和方法概述

这里列出了一些有用的NumPy函数和方法, 有关完整列表,请参阅例程:

https://docs.scipy.org/doc/numpy-dev/reference/routines.html#routines

相关推荐

5款Syslog集中系统日志常用工具对比推荐

一、为何要集中管理Syslog?Syslog由Linux/Unix系统及其他网络设备生成,广泛分布于整个网络。因其包含关键信息,可用于识别网络中的恶意活动,所以必须对其进行持续监控。将Sys...

跨平台、多数据库支持的开源数据库管理工具——DBeaver

简介今天给大家推荐一个开源的数据库管理工具——DBeaver。它支持多种数据库系统,包括Mysql、Oracle、PostgreSQL、SLQLite、SQLServer等。DBeaver的界面友好...

强烈推荐!数据库管理工具:Navicat Premium 16.3.2 (64位)

NavicatPremium,一款集数据迁移、数据库管理、SQL/查询编辑、智能设计、高效协作于一体的全能数据库开发工具。无论你是MySQL、MariaDB、MongoDB、SQLServer、O...

3 年 Java 程序员还玩不转 MongoDB,网友:失望

一、什么场景使用MongoDB?...

拯救MongoDB管理员的GUI工具大赏:从菜鸟到极客的生存指南

作为一名在NoSQL丛林中披荆斩棘的数据猎人,没有比GUI工具更称手的瑞士军刀了。本文将带你围观五款主流MongoDB管理神器的特性与暗坑,附赠精准到扎心的吐槽指南一、MongoDBCompass:...

mongodb/redis/neo4j 如何自己打造一个 web 数据库可视化客户端?

前言最近在做neo4j相关的同步处理,因为产线的可视化工具短暂不可用,发现写起来各种脚本非常麻烦。...

solidworks使用心得,纯干货!建议大家收藏

SolidWorks常见问题...

统一规约-关乎数字化的真正实现(规范统一性)

尽管数字化转型的浪潮如此深入人心,但是,对于OPCUA和TSN的了解却又甚少,这难免让人质疑其可实现性,因为,如果缺乏统一的语义互操作规范,以及更为具有广泛适用的网络与通信,则数字化实际上几乎难以具...

Elasticsearch节点角色配置详解(Node)

本篇文章将介绍如下内容:节点角色简介...

产前母婴用品分享 篇一:我的母婴购物清单及单品推荐

作者:DaisyH8746在张大妈上已经混迹很久了,有事没事看看“什么值得买”已渐渐成了一种生活习惯,然而却从来没有想过自己要写篇文章发布上来,直到由于我产前功课做得“太过认真”(认真到都有点过了,...

比任何人都光彩照人的假期!水润、紧致的肌肤护理程序

图片来源:谜尚愉快的假期临近了。身心振奋的休假季节。但是不能因为这种心情而失去珍贵的东西,那就是皮肤健康。炙热的阳光和强烈的紫外线是使我们皮肤老化的主犯。因此,如果怀着快乐的心情对皮肤置之不理,就会使...

Arm发布Armv9边缘AI计算平台,支持运行超10亿参数端侧AI模型

中关村在线2月27日消息,Arm正式发布Armv9边缘人工智能(AI)计算平台。据悉,该平台以全新的ArmCortex-A320CPU和领先的边缘AI加速器ArmEthos-U85NPU为核心...

柔性——面向大规模定制生产的数字化实现的基本特征

大规模定制生产模式的核心是柔性,尤其是体现在其对定制的要求方面。既然是定制,并且是大规模的定制,对于制造系统的柔性以及借助于数字化手段实现的柔性,就提出了更高的要求。面向大规模定制生产的数字化业务管控...

创建PLC内部标准——企业前进的道路

作者:FrankBurger...

标准化编程之 ----------- 西门子LPMLV30测试总结

PackML乃是由OMAC开发且被ISA所采用的自动化标准TR88.00.02,能够更为便捷地传输与检索一致的机器数据。PackML的主要宗旨在于于整个工厂车间倡导通用的“外观和感觉”,...

取消回复欢迎 发表评论: