简介

numpy.array() 数组对象,可以表示普通的一维数组,或者二维矩阵,或者任意数据;并且它可以对数组中的数据进行非常高效的运算,如:数据统计、图像处理、线性代数等

numpy 之所以能运行这么快的原因是因为它底层是用C语言实现的目标代码,但对于需要运算的数据需要先将它们表示成numpy数组的形式,即向量化

numpy 的基本使用

首先导入库并去别名np:

import numpy as np

1.创建数组

1.1 创建指定初始化变量数组

np.array([1,2,3,4,5])

1.2 创建全零的 3行2列 的数组

np.zeros((3,2))

1.3 创建全为1的 2行4列 的数组

np.ones((2,4))

1.4 创建递增或递减数组

np.arange(3,7)  #递增
np.arange(9,1,-1) #递减

1.5 返回介于某区间等间距分布的数

np.linspace(0,1,5)
#介于0-1之间等间距的5位数

1.6 生成一个随机的 2行4列 的数组

np.random.rand(2,4)

2.获取数组尺寸

a = np.zeros((3,2))
a.shape

3.获取数组随机的数组类型

默认数组类型为64位的浮点型(np.float64)

3.1 创建数组时指定其他数组类型

a = np.zeros((4,2), dtype=np.int32)

3.2 对现有的数组进行数据类型转换

a = np.zeros((2,4))
b = a.astype(int)

基本运算

1.相同尺寸的数组可以直接进行四则运算

1.1 将数组同位置的数进行加减乘除

a = np.array([1,2,3])
b = np.array([4,5,6])
print(a+b)
print(a/b)

1.2 将两个向量进行点乘运算

同位置的数相乘再相加

a = np.array([1,2,3])
b = np.array([4,5,6])
np.dot(a,b)

1.3 进行矩阵的乘法运算

等同于np.matmul()函数

a = np.array([[1,2],
[3,4]])
b = np.array([[2,0],
[0,2]])
print(a @ b)

1.4 对所有数一次求平方根

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

1.5 进行三角函数运算

a = np.array([1,2,3])
np.sin(a)
np.cos(a)

1.6 进行对数或指数的运算

a = np.array([1,2,3])
np.log(a)
np.power(a,2)

1.7 数组云单独的一个数做运算

分别计算各个元素与这个数的加减乘除,产生一个同尺寸的新数组,即称为“广播”

a = np.array([1,2,3])
a*5

2.不用尺寸的数组进行运算

运算前,numpy 会将两个数组扩展至相同尺寸,然后再将相同位置的元素相加

3.一维数组返回数组中所需的值

3.1 返回数组中最小或最大的元素

a = np.array([1,2,3,4,5])
a.min()
a.max()

3.2 返回最小或最大元素所在的索引

a = np.array([1,2,3,4,5])
a.argmin()
a.argmax()

3.3 返回所有数据的总和

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

3.4 返回数据的平均值

a = np.array([1,2,3,4,5])
a.mean()
np.median()

3.5 返回数据的方差和标准方差等

a = np.array([1,2,3,4,5])
a.var()
a.std()

4.对于多维数组

可以指定一个额外的参数axis

当axis=0时,它会将每一行中对应的数据相加,axis=0代表第一个维度,即为 行

a = np.array([[1,2,3,4,5],
[5,6,7,8,9]])
a.sum(axis=0)

当axis=1时,代表第二个维度, 即为 列

a = np.array([[1,2,3,4,5],
[5,6,7,8,9]])
a.sum(axis=1)

5.获取数组中的元素

5.1获取第一行第二列的元素

a = np.array([[1,2,3],
[4,5,6]])
a[0,1]

5.2 按条件筛选指定的元素

a = np.arange(10)
a[a<3] #返回a<3的元素
a[(a>3)&(a%2==0)] #返回a>3且是偶数的数

5.3 获取第一行一到二列的元素

a = np.array([[1,2,3],
[4,5,6]])
a[0,0:2]

5.4 获取第一行所有列的元素

a = np.array([[1,2,3],
[4,5,6]])
a[0, : ] 或 a[0]

5.5 每隔n个数取一个数

a = np.array([1,2,3,4,5,6,7,8,9])
a[0:9:n] #n可正可负

a[::-1] #将数组翻转

图片处理

pillow安装

pip install pillow

1.使用pillow这个库在Python中读取图片文件

from PIL import Image
im = Image.open('C:/Users/Lenovo/Desktop/02.jpg')
im.show()

2.将图片转为一个numpy数组

from PIL import Image
import numpy as np
im = Image.open('C:/Users/Lenovo/Desktop/02.jpg')

im = np.array(im)
print(im.shape)

---》(1000, 750, 3) 表示1000行,750列,有3个颜色分量

3.通过下标访问颜色分量

im[100,100]

4.单独提取出所有像素点的红色分量

im_r = im[:,:,0]
Image.fromarray(im_r).show()

5. 将两张图片按比例混合在一起

from PIL import Image
import numpy as np
im1 = np.array(Image.open('C:/Users/Lenovo/Desktop/02.jpg'))
im2 = np.array(Image.open('C:/Users/Lenovo/Desktop/01.jpg'))
im_blend = im1*0.4+im2*0.6
im_blend = im_blend.astype(np.uint8) #运算结果为浮点数

Image.fromarray(im_blend).show() #显示图片,将图片转换成整型数

6.利用跨度对图片进行降采样

im_downsample = im1[::10,::10,:]
im_downsample = im1[::10,::10,:]
print(im_downsample)

7.将图片进行翻转

im_flipped = im1[::-1,:,:]  #上下翻转
im_flipped = im1[:,::-1,:] #左右翻转
Image.fromarray(im_flipped).show()

8.裁剪图片某一部分

im_cropped = im[40:540,400:900,:]
Image.fromarray(im_cropped).show()

numpy学习笔记02的更多相关文章

  1. OpenCV 学习笔记 02 使用opencv处理图像

    1 不同色彩空间的转换 opencv 中有数百种关于不同色彩空间的转换方法,但常用的有三种色彩空间:灰度.BRG.HSV(Hue-Saturation-Value) 灰度 - 灰度色彩空间是通过去除彩 ...

  2. 软件测试之loadrunner学习笔记-02集合点

    loadrunner学习笔记-02集合点 集合点函数可以帮助我们生成有效可控的并发操作.虽然在Controller中多用户负载的Vuser是一起开始运行脚本的,但是由于计算机的串行处理机制,脚本的运行 ...

  3. NumPy学习笔记 三 股票价格

    NumPy学习笔记 三 股票价格 <NumPy学习笔记>系列将记录学习NumPy过程中的动手笔记,前期的参考书是<Python数据分析基础教程 NumPy学习指南>第二版.&l ...

  4. NumPy学习笔记 二

    NumPy学习笔记 二 <NumPy学习笔记>系列将记录学习NumPy过程中的动手笔记,前期的参考书是<Python数据分析基础教程 NumPy学习指南>第二版.<数学分 ...

  5. NumPy学习笔记 一

    NumPy学习笔记 一 <NumPy学习笔记>系列将记录学习NumPy过程中的动手笔记,前期的参考书是<Python数据分析基础教程 NumPy学习指南>第二版.<数学分 ...

  6. numpy 学习笔记

    numpy 学习笔记 导入 numpy 包 import numpy as np 声明 ndarray 的几种方法 方法一,从list中创建 l = [[1,2,3], [4,5,6], [7,8,9 ...

  7. 机器学习实战(Machine Learning in Action)学习笔记————02.k-邻近算法(KNN)

    机器学习实战(Machine Learning in Action)学习笔记————02.k-邻近算法(KNN) 关键字:邻近算法(kNN: k Nearest Neighbors).python.源 ...

  8. Numpy学习笔记(下篇)

    目录 Numpy学习笔记(下篇) 一.Numpy数组的合并与分割操作 1.合并操作 2.分割操作 二.Numpy中的矩阵运算 1.Universal Function 2.矩阵运算 3.向量和矩阵运算 ...

  9. Numpy学习笔记(上篇)

    目录 Numpy学习笔记(上篇) 一.Jupyter Notebook的基本使用 二.Jpuyter Notebook的魔法命令 1.%run 2.%timeit & %%timeit 3.% ...

随机推荐

  1. 【面试普通人VS高手系列】谈谈你对Seata的理解

    很多面试官都喜欢问一些"谈谈你对xxx技术的理解". 大家遇到这种问题时,是不是完全不知道从何说起. 那么我们来看一下,普通人和高手是如何回答这个问题的? 普通人: Seata是用 ...

  2. UML中类关系表示与Java代码中的对应关系

    UML中类关系表示与Java代码中的对应关系 1. 类的UML表示法 上图中,Employee 类有两个String类型的私有属性和一个返回值为String类型public 方法 getName(); ...

  3. 深入理解Kafka核心设计及原理(五):消息存储

    转载请注明出处:https://www.cnblogs.com/zjdxr-up/p/16127749.html 目录: 5.1文件目录布局 5.2消息压缩 5.3日志索引 5.4日志文件及索引文件分 ...

  4. Apache Flink系列-④有状态函数

    有状态函数:独立于平台的有状态无服务器堆栈   这是一种在现代基础设施上创建高效.可扩展且一致的应用程序的简单方法,无论规模大小.   有状态函数是一种API,它通过为无服务器架构构建的运行时简化了分 ...

  5. Http GET 请求参数中文乱码

    两种解决方式 第1种:代码里转换 String name = request.getParamter("name"); String nameUtf8 = new String(n ...

  6. nacos 详细介绍(一)

    一.Nacos介绍 Nacos是SpringCloudAlibaba架构中最重要的组件. Nacos 是一个更易于帮助构建云原生应用的动态服务发现.配置和服务管理平台,提供注册中心.配置中心和动态 D ...

  7. nginx反向代理隐藏端口号和项目名

    可利用nginx反向代理隐藏端口号和项目名,直接输入ip即可访问对应的tomcat项目,配置nginx安装目录的nginx/conf/nginx.conf文件,修改如下:(开了两个web项目:项目名为 ...

  8. LVM从VG中删除PV及删除未知PV

    当我们的硬盘发被删除掉了,我们的PV卷会变成[unknown] 一.首先我们要备份我们的文件,然后再删除lv分区 二. VG中去除PV unknown device:

  9. 引入『客户端缓存』,Redis6算是把缓存玩明白了…

    原创:微信公众号 码农参上,欢迎分享,转载请保留出处. 哈喽大家好啊,我是没更新就是在家忙着带娃的Hydra. 在前面介绍两级缓存的文章中,我们总共给出了4种实现方案,在项目中整合了本地缓存Caffe ...

  10. Hadoop(四)C#连接Hive

    Hive Hive将HiveQL(类sql语言)转为MapReduce,完成数据的查询与分析,减少了编写MapReduce的复杂度.它有以下优点: 学习成本低:熟悉sql就能使用 良好的数据分析:底层 ...