莫烦python博客_《莫烦Python》笔记 -- numpy部分

个人感觉,在numpy里,从说法上,数组与矩阵可以互换

1.1 numpy & pandas有什么用?

1.2 numpy & pandas的安装

安装Anaconda

2.1 numpy属性

import numpy as np

# 将一个列表转化为矩阵

array = np.array([[1,2,3],

[2,3,4]])

# 查看矩阵的维度

print('dim of array:',array.ndim)

# 查看矩阵的形状

print('shape:',array.shape)

# 查看矩阵元素的个数

print('size:',array.size)

2.2 numpy创建array

import numpy as np

# 生成一个一维矩阵

a = np.array([2,3,4])

# 利用参数dtype指定列表元素的类型,常用dtype:int32/int64/float32/float64

a = np.array([2,3,4],dtype=int)

print(a.dtype)

补充:使用astype方法显示地转化矩阵的数据类型

a.astype(np.float64),这样整数就换成了浮点数

注意:将浮点数转换为整数时,会使用去尾法执行,即2.5会换算成2

# 生成一个二维矩阵

b = np.array([[2,3,4],

[3,4,5]])

# 生成一个3行4列全为0的矩阵

c = np.zeros((3,4))

# 生成一个3行4列全为1的矩阵

d = np.ones((3,4))

# 生成一个3行4列全为空值的矩阵

e = np.empty((3,4))

# 生成一个有序的矩阵:10至20步长为2的数

f = np.arange(10,20,2)

# 对生成的矩阵重新塑形

g = np.arange(12).reshape((3,4))

# 将1至10等分得到5个数

h = np.linspace(1,10,5)

i = np.linspace(1,10,6).reshape((2,3))

补充:np.random模块常用方法/函数

np.random.rand():返回给定形状的一组随机数值

np.random.randn():返回一组服从标准正态分布的数值

np.random.randint(low[, high, size]) :返回一组随机整数值 ,位于[low,high)之间

np.random.random_integers(low[, high, size])::返回一组随机整数值 ,位于[low,high]之间

np.random.random():返回一组随机的浮点数,位于[0.0,1.0)之间

np.random.ranf():返回一组随机的浮点数,位于[0.0,1.0)之间

np.random.sample():返回一组随机的浮点数,位于[0.0,1.0)之间

详细例子以及其他方法/函数可参见官网以及一篇翻译的不错的中文博客

2.3 numpy的基础运算

import numpy as np

a = np.array([10,20,30,40])

b = np.arange(4)

# 加法 +

a+b

# 减法 -

a-b

# 乘法,指对应位置相乘 *

a*b

# 除法 /

b/a

# 次方 **

b**2

# sin/cos/tan()

np.tan(a)

# 比较>,=,<=

b == 3

a = np.array([[1,1],

[0,1]])

b = np.arange(4).reshape((2,2))

# 逐个相乘,即对应位置相乘 *

c = a*b

# 矩阵乘法,两种写法 **

c_dot1 = np.dot(a,b)

c_dot2 = a.dot(b)

# 生成一个2行4列元素为0-1随机的矩阵

a = np.random.random((2,4))

# 参数axis用于控制计算方式,0表示按行计算,1为按列计算

np.sum(a)

np.sum(a,axis=0)

np.min(a)

np.min(a,axis=1)

np.max(a)

2.4 numpy的基础运算2

import numpy as np

A =np.arange(2,14).reshape(3,4)

# 找出A的最小值的索引

print(np.argmin(A))

A.mean()

np.mean(A)

np.cumsum(A) # 累加

np.diff(A) # 累差,印象中另一种说法是错位相减

np.sort(A) # 逐行排序

np.transpose(A)/A.T # 转置

np.clip(A,5,9) # 将矩阵A中小于5的数变为5,大于9的数变为9,介于5至9的数保持不变

2.5 numpy的索引

import numpy as np

A = np.arange(3,15)

A[3] # 找到矩阵A里位置为3的值

2ae3c0012fbc?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

图2.5-1

A = np.arange(3,15).reshape((3,4))

A[2] # 矩阵A的行数为2的数据

A[2][1] # 矩阵A第2行第1列的值

A[2,1] # 矩阵A第2行第1列的值

A[:,1] # 矩阵A所有行第1列的数据

A[:,1:3] # 矩阵A所有行第1至2列的值

2ae3c0012fbc?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

图2.5-2

# 按行遍历矩阵A

for row in A:

print(row)

# 按列遍历矩阵A

for column in A.T:

print(column)

# 按行遍历矩阵A,并展示为一列值

for item in A.flat:

print(item)

# 将矩阵A按行展示为一行值

A.flatten()

2ae3c0012fbc?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

图2.5-3

2ae3c0012fbc?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

图2.5-4

2.6 numpy的array合并

import numpy as np

A = np.array([1,1,1])

B = np.array([2,2,2])

C= np.vstack((A,B)) # vertical stack 上下合并

D = np.hstack((A,B)) # horizontal stack 左右合并

np.concatenate((A,B,A,B),axis =0) # 0表示纵向合并,1表示横向合并??

2ae3c0012fbc?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

图2.6-1

2.7 numpy的array分割

import numpy as np

A = np.arange(12).reshape((3,4))

# 等分分割

np.split(A,2,axis=1)

# 不等分分割

np.array_split(A,3,axis=1)

# 另外两个等分函数

np.vsplit(A,3) # 按行

np.hsplit(A,2) # 按列

2ae3c0012fbc?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

图2.7-1

2ae3c0012fbc?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

图2.7-2

2.8 numpy的copy&deep copy

import numpy as np

a = np.arange(4)

b = a

c = b

a[0]=11

a

b

c

c[1:3]=[22,33]

c

a

b

2ae3c0012fbc?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

2.8-1

2ae3c0012fbc?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

2.8-2

a = np.arange(4)

b = a.copy() # deep copy

a

b

b[1] = 45

b

a

2ae3c0012fbc?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

2.8-3

照例,文末附上小哥哥的课程地址。

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

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

相关文章

java 内存情况_java查看jvm内存使用情况

java查看jvm内存使用情况(2012-03-22 15:50:54)标签&#xff1a;jvm内存虚拟机分配itjava.lang.Runtime类提供了查看当前JVM内存的使用情况。每个java实例(即虚拟机实例)只有一个Runtime的实例&#xff0c;通过Runtime.getRuntime()可以得到当前虚拟机中的Runtime实例对象。Run…

java 密码生成器_Java课程设计-随机密码生成器

1.团队课程设计博客链接2.个人负责模板设计程序运行界面&#xff0c;数据的输入&#xff0c;判断数据输入类型的错误&#xff0c;判断密码类型是否选择。3.自己的代码提交记录截图4自己负责模块或任务详细说明(一)总体设计1.系统主要功能(1)输入生成密码长度&#xff1b;(2)判断…

pyecharts本地文件_python数据可视化-pyecharts插件使用文档

pyecharts是百度开源的可视化插件&#xff0c;可以将设计的可视化图表以html格式保存&#xff0c;配合jupyter可以一键生成动态的html数据分析报告。pyecharts和matplotlib的区别在于&#xff0c;pyecharts有更加强大交互的可视化和嵌入html的功能&#xff0c;pyecharts缺点在于…

gdal获取像元的灰度值java_GDAL利用地理坐标读取图像像元值

最近的一个项目需要在电子海图中下载已知水深点&#xff0c;导出点的地理坐标(经纬度)。然后在arcgis中打开这些地理坐标输出为shp&#xff0c;利用GDAL读取不同波段的点对应的像元值&#xff0c;从而构建水深和像元值的对应关系。其实想要根据经纬度得到像元值有两种方法。1.通…

kibana java script_Elasticsearch:创建 Runtime field 并在 Kibana 中使用它 - 7.11 发布 - TGCode...

在之前的文章 “Elasticsearch&#xff1a;使用 Runtime fields 对索引字段进行阴影处理以修复错误 – 7.11 发布”&#xff0c;我展示了如何使用 runtime field 来 shadow 一个已有的在 mapping 中的字段&#xff0c;比如 duration。在今天的练习中&#xff0c;我将展示如何创…

java根据uml图写出实现代码,根据java代码生成UML图

根据java代码生成UML图根据java代码生成UML图这里介绍一个简单易用的eclipse插件ModelGoon&#xff0c;用来对已有代码生成UML图&#xff0c;下面以之前文章中的spring mvc工程为例如何安装和使用这个插件&#xff1b;这个spring mvc工程的代码在githbu上&#xff0c;地址是&am…

highcharts php 动态数据,php动态传数据到highcharts的方法

本文主要介绍了通过php动态传数据到highcharts的相关知识。具有很好的参考价值。1&#xff1a;在平时工作中&#xff0c;在对数据进行展示的时候&#xff0c;是直接通过后台提供的接口来获取json串&#xff0c;用来展示。今天别人问怎么在本地演示一下请求的动态数据。2&#x…

php tar.gz文件,PHP解压tar.gz格式文件的方法,_PHP教程

PHP解压tar.gz格式文件的方法&#xff0c;本文实例讲述了PHP解压tar.gz格式文件的方法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;1、运用php自带压缩与归档扩展(phar)$phar new PharData(song.tar.gz);//路径 要解压的文件 是否覆盖$phar->extractTo(c:/tmp,…

创建数组表格PHP苹果价格,如何从PHP数组创建HTML表?

Cats萌萌这是我的&#xff1a;<?php function build_table($array){ // start table $html . htmlspecialchars($key) . . htmlspecialchars($value2) .

python打包exe报错编码问题,使用Python打包含有pymssql成exe所躺的坑

一、如何打包Python打包exe文件简单运用pyinstaller库就行了1)安装pyinstaller库(自行安装)2)winR打开运行窗口输入“powershell”3)输入pyinstaller -F 路径\文件名.py(打包py文件的路径&#xff0c;py不能省略)看到successfully即为打包成功&#xff0c;但不一定能运用的&…

php超大树形分页,PHP+MySql千万级数据limit分页优化方案

PHPMySql千万级数据limit分页优化方案1年前阅读 2750评论 0喜欢 0### 原因徒弟突然有个需求&#xff0c;就是他发现limit分页&#xff0c;页数越大之后&#xff0c;mysql的消耗越大&#xff0c;查询时间越长&#xff0c;当突破百万级数据之后&#xff0c;一个简单的翻页都需要5…

linux自启动配置文件,Linux中如何设置服务自启动?

有时候我们需要Linux系统在开机的时候自动加载某些脚本或系统服务&#xff0c;主要用三种方式进行这一操作&#xff1a;ln -s 在/etc/rc.d/rc*.d目录中建立/etc/init.d/服务的软链接(*代表0&#xff5e;6七个运行级别之一)chkonfig 命令行运行级别设置nts…

linux系统下升级node,linux下安装指定版本的nodejs(升级到指定版本)

原因最近需要全栈开发但是服务器是linux系统&#xff0c;服务本身通过yum安装软件包&#xff0c;不过yum安装的nodejs版本太低。所以需要自己安装。方案下载编译好的文件解压后直接运行即可&#xff0c;不过我们需要全局运行node命令。只需要把目录设置为全局即可(建立软链接 l…

Linux bash卸载软件,Ubuntu卸载软件的4种方法

前言本文重点介绍Ubuntu卸载软件的4种方法。他们分别是图形化界面的synaptic、自动解决依赖关系的apt-get&#xff0c;处理依赖关系更强大的aptitude&#xff0c;还有安装本地deb包的dpkg。方法一: Ubuntu使用synaptic图形化界面管理软件oucanrongzcwyou:~$ sudo apt-get insta…

linux系统atom安装教程,Ubuntu/Linux Mint上安装Atom文本编辑器

Atom是一款由Github开发的开源文本编辑器&#xff0c;虽然目前该软件依然在Beta阶段&#xff0c;但我们依然可以在你的Ubuntu/Linux Mint上使用它。据Atom官方博客介绍&#xff0c;与Atom类似的编辑器Sublime和TextMate都深受开发者欢迎&#xff0c;但在扩展性上都有所限制&…

labview 远程连接linux,SSH交互式通信总结:expect、plink、putty、sshpass、ALAB SSH

关于在linux脚本中远程执行命令的问题&#xff0c;笔者在以前文章中可以使用expect工具来完成交互式通信。在windows平台下可以使用plink或者putty工具。免密也可以设置SSH秘钥&#xff0c;参考文章-Linux怎么远程执行指令呢-SSH秘钥。但是在linux下需要一一对应设置&#xff0…

tcping在linux用法,tcping的安装和使用

Tcping 网上比较少资料是关于linux对tcp端口ping测试的方法&#xff0c;我这里简单介绍2种方法&#xff1a; 1.yum安装&#xff0c;编译安装方法 1-1.wget http://linuxco.de/tcping/tcping-1.3.5.tar.gz ###下载tcping1-2 tar zxvf tcping-1.3.5.tar.gz ####解压缩tcping-1.3.…

linux子系统安装gromacs,科学网—Windows下GROMACS程序的编译 - 李继存的博文

2015-12-07 22:12:05总的来说, Windows下的GROMACS程序用于模拟意义不大, 对于长时间的模拟, 我都是放在Linux服务器上进行的. 但将Windows下的GROMACS程序作为一个辅助工具来使用还是有意义的. 因为大多数时候, 我都是在Windows下准备输入文件的, 然后测试一下准备好的输入文件…

林锐 高质量c语言编程下载,新年献礼:Go语言深度入门手册

(文末的阅读原文&#xff0c;效果最佳&#xff01;)作者&#xff1a;李佶澳 微信&#xff1a;lijiaocnGo 语言深度入门手册&#xff0c;帮你更好的理解 Go 语言&#xff0c;写出更高效、更规范、更不易出错的代码。Go 在 2012 年发布 1.0 版本&#xff0c;距今已经 8 年了。和历…

永洪报表工具_2020年最值得推荐的五大BI工具

现在很多公司和业务部门都十分注重数据分析&#xff0c;并为企业信息化建设做准备。以前收集、处理、分析数据可能是IT部门和数据库员的专属&#xff0c;现在很多业务部门都急切的开始用数据分析的思维分析业务问题。在过去&#xff0c;大多数数据人员的工作模式都是自己使用ex…