numpy小记
import numpy as np
#
a=np.array([[1,3,2],[4,5,6]])
print(a)
a=np.arange(1,13).reshape((3,4))#生成一个3行4列的矩阵。值是1~13范围内的随机数字
#
b=a.reshape(2,-1)#明确指定矩阵为2行,-1表示一个占位符(在这里指定是3,一般情况下它一直都会是-1)
print(b)
print(a[1,1])#打印的是5 第2行,第2列的数字。默认从0开始计数
a[1,1]=55
print(a)
b=np.zeros((3,3))#创建一个3x3的矩阵,默认值全都为0
c=np.ones((3,3))#创建一个3x3的矩阵,默认值全都为1
d=np.full((3,3),5)#创建一个3x3的矩阵,默认值全都为5
print(d)
e=np.eye(3)#创建一个单位矩阵
print(e)
f=np.random.random((3,4))#创建随机矩阵 3x4
print(f)
#索引操作(和一般的列表操作类似,负数表示相反方向)
g=np.array([[1,2,3,4],[3,4,5,6],[6,7,8,9]])
h=g[1:,1:4]#从第2行,第1列开始,取值print(h.dtype) #打印矩阵中数值的类型
k=np.array([1.5,2.6,3.3])
l=np.array(k,dtype=np.int64)#会将矩阵中所有的数都转化成整数
print(g[1,3])#返回6(行与列都是从0开始计算的)
print(g[2,:])#返回第二行所有的值。
print(g[:,3])#返回第三列所有的值
print(g[0:2,1:3])#返回一个矩形区域的值。其中0:2是指获取第0行和第1行的数据。1:3是指获取第1列和第2列的数据
#numpy中的常用运算
ary1=np.array([[5,6],[7,8]])
ary2=np.array([[8,1],[3,2]])
print(ary1+ary2)#两个矩阵做加法运算(np.add(ary1,ary2))
print(ary1-ary2)#两个矩阵做减法运算,相当于np.subtract(ary1,ary2)
print(ary1/ary2)#两个矩阵做除法运算,相当于np.divide(ary1,ary2)
print(ary1*ary2)#将两个矩阵,相同位置上的数做乘法运算。相当于np.multiply(ary1,ary2)
#两个矩阵相乘 当前者的列数等于后者的行数,才能进行矩阵的乘法运算
print(ary1.dot(ary2))#相当于np.dot(ary1,ary2)
print(np.sum(ary1))#对ary中的数进行求和操作。结果是26
print(np.sum(ary1,axis=0))#得到一个一维矩阵,将矩阵中的每一列进行求和操作
print(np.sum(ary1,axis=1))#对矩阵中的每一行进行求和操作
np.mean(ary1)#求得矩阵中,所有数的和的平均值
np.mean(ary1,axis=0)#求得矩阵中,每一列数的和的平均值
np.mean(ary1,axis=1)#求得矩阵中,每一行数的和的平均值
print(np.random.uniform(0,1))#产生一个随机数(0和1之间)
print(np.average(ary1))#获取矩阵的平均数
print(np.median(ary1))#获取矩阵的中位数
np.cumsum(ary1)#返回一个列表,该列表内的元素的数量和矩阵的数量相同。列表的第2位数是矩阵的前2个数相加得来的。第3位数是矩阵前3个数相加得来的,第4位数是矩阵前4位……
np.diff(ary1)#返回一个矩阵,该矩阵第1位元素是ary1矩阵中,第2位和第1位元素的差。矩阵的第2位元素是ary1矩阵中,第3位元素和第2位元素的差。矩阵的第3位元素是矩阵ary1……
np.sort(ary1)#返回一个矩阵,将矩阵ary1进行逐行的排序
np.clip(ary1,3,6)#返回一个矩阵。将ary1矩阵中所有小于3的数,全都变成3,大于6的数,全都变成6
np.tile(ary1,(2,3))#将ary1这个矩阵,在行上重复2次,在列上重复3次
ary1.argsort()#将矩阵中的数进行 行(hang)排序
ary1.argsort(axis=0)#将矩阵中的数进行 列排序
np.argmin(ary1)#返回矩阵中最小值的索引
np.argmax(ary1)#返回矩阵中最大值的索引
ary1.T#矩阵的转置操作 等同于np.transpose(ary1)
ary3=np.array([1,3,2])
#将ary1的每一行和ary3进行相加
ary1+np.tile(ary3,(4,1))#在行上操作4次,在列上操作1次
a=np.array([1,1,1])
b=np.array([2,2,2])
#c=np.vstack((a,b)) #合并序列 vertical(上下合并)
#c=np.hstack((a,b))#左右合并
a=np.array([1,1,1])[:,np.newaxis]#在列上面增加一个维度,这样就可以使用concatenate来合并序列了
b=np.array([2,2,2])[:,np.newaxis]#如果np.newaxis放在了逗号的前面,则表示在列上面增加一个维度。(显然这里不需要,因为有3列了)
c=np.concatenate((a,b),axis=1)
c=np.concatenate((a,b,b,a),axis=0)#横向合并 #将矩阵分割成数组
np.split(array1,3,axis=0)#横向分割
np.hsplit(array1,3)
np.vsplit(array1,3)#纵向分割
d=a
d=a.copy()
print(c)
numpy小记的更多相关文章
- 临时处理小记:把Numpy的narray二进制文件转换成json文件
临时处理一个Numpy的二进制文件,分析知道里面是dict类型,简单小记一下,如果Numpy和Python基础不熟悉可以看我之前写的文章 In [1]: %%time import numpy as ...
- numpy教程:排序、搜索和计数
http://blog.csdn.net/pipisorry/article/details/51822775 numpy排序.搜索和计数函数和方法.(重新整合过的) ],, , ], [, , ]] ...
- [原]Paste.deploy 与 WSGI, keystone 小记
Paste.deploy 与 WSGI, keystone 小记 名词解释: Paste.deploy 是一个WSGI工具包,用于更方便的管理WSGI应用, 可以通过配置文件,将WSGI应用加载起来. ...
- 利用Python进行数据分析(5) NumPy基础: ndarray索引和切片
概念理解 索引即通过一个无符号整数值获取数组里的值. 切片即对数组里某个片段的描述. 一维数组 一维数组的索引 一维数组的索引和Python列表的功能类似: 一维数组的切片 一维数组的切片语法格式为a ...
- 利用Python进行数据分析(4) NumPy基础: ndarray简单介绍
一.NumPy 是什么 NumPy 是 Python 科学计算的基础包,它专为进行严格的数字处理而产生.在之前的随笔里已有更加详细的介绍,这里不再赘述. 利用 Python 进行数据分析(一)简单介绍 ...
- 利用Python进行数据分析(6) NumPy基础: 矢量计算
矢量化指的是用数组表达式代替循环来操作数组里的每个元素. NumPy提供的通用函数(既ufunc函数)是一种对ndarray中的数据进行元素级别运算的函数. 例如,square函数计算各元素的平方,r ...
- python安装numpy、scipy和matplotlib等whl包的方法
最近装了python和PyCharm开发环境,但是在安装numpy和matplotlib等包时出现了问题,现总结一下在windows平台下的安装方法. 由于现在找不到了工具包新版本的exe文件,所以采 ...
- 深入理解numpy
一.为啥需要numpy python虽然说注重优雅简洁,但它终究是需要考虑效率的.别说运行速度不是瓶颈,在科学计算中运行速度就是瓶颈. python的列表,跟java一样,其实只是一维列表.一维列表相 ...
- Python Numpy,Pandas基础笔记
Numpy Numpy是python的一个库.支持维度数组与矩阵计算并提供大量的数学函数库. arr = np.array([[1.2,1.3,1.4],[1.5,1.6,1.7]])#创建ndarr ...
随机推荐
- 01 初识HTML
HTML是什么? 超文本标记语言(Hypertext Markup Language, HTML)是一种用于创建网页的标记语言. 本质上是浏览器可识别的规则,我们按照规则写网页,浏览器根据规则渲染我们 ...
- python之BeautifulSoup4
阅读目录 1.Beautiful Soup4的安装配置 2.BeautifulSoup的基本用法 (1)节点选择器(tag) (2)方法选择器 (3)CSS选择器 (4)tag修改方法 Beautif ...
- document.body.scrollTop无效的解决方法
1.document.body.scrollTop = 0 有时候不生效,两种解决方案,试试看. 1-1.设置:document.documentElement.scrollTop = 0;1-2.设 ...
- appium 自动化测试环境搭建
最近再学习appium,把学习的过程记录下来,以防止到时候 换个电脑就不知道这么安装搭建appium环境了. 环境搭建: 0.JDK环境是必备的,这里大家自行百度, 1.安装 node 环境,前辈 ...
- mui在tab选项卡中echarts图表不能动态随页面变化大小 只能固定大小
在mui tab选项卡中一直都不能让echarts动态变化大小 只能固定大小来展示图表,网上说的window.onresize = mycharts.resize;方法根本就没有效果,后面在https ...
- CentOS6.5增加挂载点容量
一.背景:因为公司虚拟机 (/) 目录容量过小,导致一些任务不能正常执行,需要给虚拟机扩容 二.操作: 初始磁盘情况: 1.使用 df 命令查看磁盘与目录的容量: [root@shaonian ~]# ...
- keras多gpu训练
使用multi_gpu_model即可.观察了一下GPU的利用率,非常的低,大部分时候都是0,估计在相互等待,同步更新模型: 当然了,使用多GPU最明显的好处是可以使用更大的batch size im ...
- 使用SpringBoot做Javaweb时,数据交互遇到的问题
有段时间没做过javaweb了,有点生疏了,js也忘记得差不多,所以今天下午做前后端交互的时候,传到后台的参数总是为空,前端控制台了报一个String parameter “xxx” is not p ...
- 使用fastjson的parseObject方法将json字符串转换成Map 或者List
fastjson 转换成map HashMap<String,String> map = JSON.parseObject(jsonStr,new TypeReference<Has ...
- DeepFaceLab更新至2019.12.23
本次更新主要是增加了脸图样本生成器,一般来说我们提取脸图之后会放到aligned文件夹里面,训练的时候会加载这些脸图,若是图片少还行,一旦图片太多加载效率低不说,同样会影响了训练效率.现在好了,我们只 ...