python numpy学习
以下代码来源于本博文作者观看大神视频并纯手敲。
目录
numpy的属性
创建array
numpy的运算1
随机数生成以及矩阵的运算2
numpy的索引
array合并
array分割
numpy的浅拷贝和深拷贝
numpy的属性
import numpy as np
array = np.array([[1, 2, 3], [4, 5, 6], [7, 8, 9]])
print(array)
print(array.ndim) # 维度 2
print(array.shape) # 形状 (3, 3)
print(array.size) # 大小 9
print(array.dtype) # 元素类型 int32
numpy创建array
import numpy as np
a = np.array([1, 2, 3], dtype=np.int32)
print(a.dtype) # int32
b = np.array([1, 2, 3], dtype=np.float)
print(b.dtype) # float64
c = np.array([1, 2, 3])
d = np.array([[1, 2, 3], [4, 5, 6]])
print(d) # 二维矩阵
zero = np.zeros((2, 3))
print(zero) # 生成两行三列全为零的矩阵
one = np.ones((3, 4))
print(one) # 生成三行四列全为1的矩阵
empty = np.empty((3, 2))
print(empty) # 生成三行两列全都接近于零的矩阵(但不等于0)
e = np.arange(10)
print(e)
f = np.arange(4, 12)
print(f) # [ 4 5 6 7 8 9 10 11]
g = np.arange(1, 20, 3)
print(g)
h = np.arange(8).reshape(2, 4)
print(h) # 重新定义矩阵形状
numpy矩阵的运算
import numpy as np
arr1 = np.array([[1, 2, 3], [4, 5, 6]])
arr2 = np.array([[1, 1, 2], [2, 3, 3]])
print(arr1 + arr2) # 按照位置相加
print(arr1 - arr2)
print(arr1 * arr2)
print(arr1 ** arr2)
print(arr1 / arr2)
print(arr1 % arr2)
print(arr1 // arr2)
print(arr1 + 2) # 所有的元素都加2
arr3 = arr1 > 3
print(arr3) # 判断哪些元素大于3
arr4 = np.ones((3, 5))
print(arr4)
print(arr1)
res = np.dot(arr1, arr4) # 矩阵的乘法
print(res)
res1 = arr1.dot(arr4) # 矩阵的乘法
print(res1)
print(arr1.T) # 转置矩阵
print(np.transpose(arr1)) # 转置矩阵
随机数生成以及矩阵的运算2
import numpy as np
sample1 = np.random.random((3, 2)) # 生成3行2列的从0到1的随机数
print(sample1)
sample2 = np.random.normal(size=(3, 2)) # 生成3行2列符合标准正太分布的随机数
print(sample2)
sample3 = np.random.randint(0, 10, size=(3, 2)) # 生成3行2列的从0-10的随机整数
print(sample3)
print(np.sum(sample1)) # 求和
print(np.min(sample1)) # 求最小值
print(np.sum(sample1, axis=0)) # 对每一列进行求和
print(np.sum(sample1, axis=1)) # 对每一行进行求和
print(np.argmin(sample1)) # 求最小值的索引
print(np.argmax(sample1)) # 求最大值的索引
print(np.mean(sample1)) # 求平均值
print(sample1.mean()) # 求平均值
print(np.median(sample1)) # 求中位数
print(np.sqrt(sample1)) # 开方
sample4 = np.random.randint(0, 10, size=(1, 10))
print(sample4)
print(np.sort(sample4)) # 排序:按行升序
print(np.sort(sample1))
print(np.clip(sample4, 2, 7)) # 小于2的变成2,大于7的变成7
numpy的索引
import numpy as np
arr1 = np.arange(2, 14)
print(arr1) # [ 2 3 4 5 6 7 8 9 10 11 12 13]
print(arr1[2]) # 4
print(arr1[1: 4]) # [3 4 5]
print(arr1[2: -1]) # [ 4 5 6 7 8 9 10 11 12]
print(arr1[: 5]) # [2 3 4 5 6]
print(arr1[-2:]) # [12 13]
arr2 = arr1.reshape(3, 4)
print(arr2) #
print(arr2[1]) # [6 7 8 9]
print(arr2[1][1]) # 7
print(arr2[1, 2]) # 8
print(arr2[:, 2]) # [ 4 8 12] 所有行,第2列
for i in arr2: # 迭代行
print(i)
for i in arr2.T: # 迭代列
print(i)
for i in arr2.flat: # 迭代一个个元素
print(i)
array的合并
import numpy as np
arr1 = np.array([1, 2, 3])
arr2 = np.array([4, 5, 6])
arr3 = np.vstack((arr1, arr2)) # 垂直合并
print(arr3)
print(arr3.shape)
arr4 = np.hstack((arr1, arr2)) # 水平合并
print(arr4) # [1 2 3 4 5 6]
print(arr4.shape)
arrv = np.vstack((arr1, arr2, arr3))
print(arrv)
arrh = np.hstack((arr1, arr2, arr4))
print(arrh)
arr = np.concatenate((arr1, arr2, arr1)) # 合并
print(arr)
arr = np.concatenate((arr3, arrv), axis=0) # 垂直合并。合并的array维度要相同,array形状要匹配,axis=0纵向合并
print(arr)
arr = np.concatenate((arr3, arr3), axis=1) # 水平合并
print(arr)
print(arr1.T) # 一维的array不能转置
print(arr1.shape) # (3,)
arr1_1 = arr1[np.newaxis, :]
print(arr1_1) # [[1 2 3]]
print(arr1_1.shape) # (1, 3)
print(arr1_1.T)
arr1_2 = arr1[:, np.newaxis]
print(arr1_2)
print(arr1_2.shape) # (3, 1)
arr1_3 = np.atleast_2d(arr1)
print(arr1_3) # [[1 2 3]]
print(arr1_3.T)
array分割
import numpy as np
arr1 = np.arange(12).reshape((3, 4))
print(arr1)
arr2, arr3 = np.split(arr1, 2, axis=1) # 水平方向分割,分成2份
print(arr2)
print(arr3)
arr4, arr5, arr6 = np.split(arr1, 3, axis=0) # 垂直方向分割,分成2份
print(arr4)
print(arr5)
print(arr6)
arr7, arr8, arr9 = np.array_split(arr1, 3, axis=1) # 水平方向分割成3份,不等分割
print(arr7)
print(arr8)
print(arr9)
arrv1, arrv2, arrv3 = np.vsplit(arr1, 3) # 垂直分割
print(arrv1)
print(arrv2)
print(arrv3)
arrh1, arrh2 = np.hsplit(arr1, 2) # 水平分割
print(arrh1)
print(arrh2)
numpy的浅拷贝和深拷贝
import numpy as np
arr1 = np.array([1, 2, 3])
arr2 = arr1 # 引用赋值,共享一块内存,浅拷贝
arr2[0] = 5
print(arr1)
print(arr2)
arr3 = arr1.copy() # 深拷贝
arr3[0] = 10
print(arr1)
print(arr3)
转载请注明博文出处。
python numpy学习的更多相关文章
- Python NumPy学习总结
一.NumPy简介 其官网是:http://www.numpy.org/ NumPy是Python语言的一个扩充程序库.支持高级大量的维度数组与矩阵运算,此外也针对数组运算提供大量的数学函数库.Num ...
- python numpy 学习
例子 >>> import numpy as np >>> a = np.arange(15).reshape(3, 5) >>> a array ...
- python numpy学习记录
numpy是一个python和矩阵相关的库,在机器学习中非常有用,记录下numpy的基本用法 numpy的数组类叫做ndarray也叫做数组,跟python标准库中的array.array不同,后者只 ...
- Python numpy学习笔记(一)
下边代码是关于numpy的一些基本用法,包括数组和矩阵操作等... import numpy as np print "<== print version ==>" p ...
- (转)Python数据分析之numpy学习
原文:https://www.cnblogs.com/nxld/p/6058572.html https://morvanzhou.github.io/tutorials/data-manipulat ...
- Python: NumPy, Pandas学习资料
NumPy 学习资料 书籍 NumPy Cookbook_[Idris2012] NumPy Beginner's Guide,3rd_[Idris2015] Python数据分析基础教程:NumPy ...
- Python数据分析:Numpy学习笔记
Numpy学习笔记 ndarray多维数组 创建 import numpy as np np.array([1,2,3,4]) np.array([1,2,3,4,],[5,6,7,8]) np.ze ...
- Comprehensive learning path – Data Science in Python深入学习路径-使用python数据中学习
http://blog.csdn.net/pipisorry/article/details/44245575 关于怎么学习python,并将python用于数据科学.数据分析.机器学习中的一篇非常好 ...
- Day1 Python基础学习
一.编程语言分类 1.简介 机器语言:站在计算机的角度,说计算机能听懂的语言,那就是直接用二进制编程,直接操作硬件 汇编语言:站在计算机的角度,简写的英文标识符取代二进制去编写程序,本质仍然是直接操作 ...
随机推荐
- 虚拟环境:virtualenv与virtualenvwrapper
前言: 在使用 Python 开发的过程中,工程一多,难免会碰到不同的工程依赖不同版本的库的问题: 亦或者是在开发过程中不想让物理环境里充斥各种各样的库,引发未来的依赖灾难. 此时,我们需要对于不同的 ...
- 【Maven学习笔记】mvn help:system 命令的说明
mvn help:system 命令的说明 笔者用得是windows 10 x64系统 下载了Maven3,正确配置了系统变量M2_HOME的值,并且添加到Path变量路径当中. 简单来说,Maven ...
- FPGA时序约束理解记录
最近整理了一下时序约束的内容,顺便发出来分享记录一下. 任何硬件想要工作正常,均需满足建立和保持时间,至于这个概念不再陈述. 下面将重点介绍两个概念:建立余量和保持余量.FPGA内部进行时序分析无非就 ...
- 【PyTorch教程】P3. Python学习中的两大法宝函数(当然也可以用在PyTorch)
温馨提示:为了更好的教程体验,提供视频.阅读地址 Youtube: https://www.youtube.com/playlist?list=PLgAyVnrNJ96CqYdjZ8v9YjQvCBc ...
- ie浏览器兼容性的入门解决方案
IE浏览器的兼容性素来是令人头疼的问题,大名鼎鼎的FUCK-IE不是浪得虚名的. 这里使用的解决方案是HACK,具体原理就是针对不同的浏览器写不同的HTML.CSS样式,从而使各种浏览器达到一致的渲染 ...
- 近期学习es6后对变量提升及let和const的一点思考
1.变量提升:(创建->初始化)-->赋值-->修改 就是说,以var声明的变量,它的声明会被提升到当前作用域的顶端(注意是变量声明提升,变量的赋值没有提升) //在if语句中也会提 ...
- python学习之【第八篇】:Python中的函数基础
1.前言 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段.函数能提高应用的模块性,和代码的重复利用率. 2.函数的定义 定义函数时需要遵守以下规则: 函数代码块以 def 关键词开头 ...
- Project Euler 52: Permuted multiples
可以看到数字125874的两倍251748和它有着完全相同的数字,只是顺序不同而已.求一个最小的正整数\(x\),使得\(2x,3x,4x,5x,6x\)都有完全相同的数字. 分析:此题的思路比较直接 ...
- 如何利用缓存机制实现JAVA类反射性能提升30倍
一次性能提高30倍的JAVA类反射性能优化实践 文章来源:宜信技术学院 & 宜信支付结算团队技术分享第4期-支付结算部支付研发团队高级工程师陶红<JAVA类反射技术&优化> ...
- Python 基础 三 反射
Python 基础 三 反射 今天我们先介绍一下反射这个概念,啥是反射?反射就是自己检测自己.在我们Python的面向对象中的反射是啥意思呢?就是通过字符串的形式操作对象相关的属性.python中的一 ...