numpy 库简单使用
numpy 库简单使用
一、numpy库简介
Python标准库中提供了一个array类型,用于保存数组类型的数据,然而这个类型不支持多维数据,不适合数值运算。作为Python的第三方库numpy便有了用武之地。
numpy库处理的最基础数据类型是用同种元素构成的多维数组(ndarray),简称数组。数组中所有元素的类型必须相同,数组中元素可以用整数索引,序号从0开始。ndarray类型的维度叫作轴(axes),轴的个数叫做秩(rank)。
二、numpy库下载
pip install numpy
三、导入库函数
import numpy as np
四、库函数基本使用
1. 创建数组的函数 (ndarray类型)
|
函数 |
说明 |
|
np.array([ x, y, z], dtype = int) |
从列表或数组中创建数组 |
|
np.arange(x, y, i) |
创建一个由x到y,以i为步长的数组 |
|
np.linspace(x, y, n) |
创建一个由x到y,等分成n个元素的数组 |
|
创建一个m行n列的矩阵(3维数组) |
|
|
np.random.rand(m, n) |
创建一个m行n列的随机数组 |
|
np.ones((m,n), dtype) |
创建一个m行n列的全1数组,dtype为数据类型 |
|
np.zeros((m,n), dtype) |
创建一个m行n列的全0数组,dtype为数据类型 |
|
创建一个m行n列的空数组,dtype为数据类型 |
import numpy as np ''' numpy --> array() '''
a1 = np.array([1,2,3,5,8,13,21,34,55,89], dtype = int) # 由列表创建数组
array_ = (2.3,8,10/3,5.0,1/7) # 创建元组
a2 = np.array(array_) # 由元组创建数组
print('numpy --> array():\n',a1,'\n',a2) ''' numpy --> arange() '''
arange_1 = np.arange(1,30,4)
arange_2 = np.arange(1,3,0.4)
print('numpy --> arange():\n',arange_1,'\n',arange_2) ''' numpy --> linspace() '''
lins_1 = np.linspace(1,10,10)
lins_2 = np.linspace(1,10,9, dtype = int)
print('numpy --> linspace():\n',lins_1,'\n',lins_2) ''' numpy --> random.rand() '''
rand_ = np.random.rand(3,4)
print('numpy --> random.rand():\n',rand_) ''' numpy --> ones() '''
ones_1 = np.ones((3,4)) # 默认为float
ones_2 = np.ones((3,4),dtype = int)
print('numpy --> ones():\n',ones_1,'\n',ones_2) ''' numpy --> zeros() '''
zeros_1 = np.zeros((2,3))
zeros_2 = np.zeros((2,3), dtype = int)
print('numpy --> zeros():\n',zeros_1,'\n',zeros_2)
2. ndarray类型的常用属性
|
属性 |
说明 |
|
ndarray.ndim |
返回数组轴的个数,即数组的秩 |
|
ndarray.shape |
返回数组在每个维度上大小的整数元组 |
|
ndarray.size |
返回数组元素的总个数 |
|
ndarray.dtype |
返回数组元素的数据类型 |
|
ndarray.itemsize |
返回数组元素的字节大小 |
|
ndarray.data |
返回数组元素的缓存区地址 |
|
ndarray.flat |
数组元素的迭代器 |
import numpy as np
a = np.indices((5,8)) # 创建一个m行n列的矩阵
print("数组a的秩:",a.ndim)
print("数组a各维度的大小:",a.shape)
print("数组a元素的总个数:",a.size)
print("数组a元素的数据类型:",a.dtype)
print("数组a元素的字节大小:",a.itemsize)
print("数组a元素的缓存区地址:",a.data)
print("数组a元素的迭代器:",a.flat)
print("数组a的元素:\n",a)
3. ndarray类型的形态操作方法
|
操作方法 |
说明 |
|
ndarray.reshape(n, m) |
返回一个维度为(n, m)的数组副本 |
|
ndarray.resize(new_shape) |
修改数组的维度大小 |
|
ndarray.swapaxes(ax1, ax2) |
调换数组ax1维度与ax2维度,返回调换后的数组 |
|
ndarray.flatten() |
对数组进行降维,返回一维数组 |
|
ndarray.ravel() |
对数组进行降维,返回数组的一个视图 |
import numpy as np
a = np.arange(20)
print('(1) 创建一维数组a:\n',a)
b = a.reshape(2,10)
print('(2) 由a创建(2,10)的数组b:\n',b)
a.resize(4,5)
print('(3) 修改数组a为(4,5):','Shape of a:',a.shape,'\n',a)
c = a.swapaxes(0,1)
print('(4) 调换数组a第1维度与第2维度得到数组c:(5,4)','Shape of c:',c.shape,'\n',c)
d = a.flatten()
print('(5) 对数组a降维,得到一维数组d:','Shape of d:',d.shape,'\n',d)
e = a.ravel()
print('(6) 对数组a降维,得到数组a的视图e','Shape of e:',e.shape,'\n',e)
4. ndarray类型的索引与切片方法
|
方法 |
说明 |
|
x [i] |
索引数组x的第i个元素 |
|
x [-i] |
从后往前索引数组x的第i个元素 |
|
x [n : m] |
从前往后索引数组x,不包含第m个元素 |
|
x [-m : -n] |
从后往前索引数组x,结束位置为n |
|
x [n : m: i] |
以i为步长索引数组x |
import numpy as np
a = np.arange(8)
print('a:',a)
print('a[4]:',a[4])
print('a[-6:-3]:',a[-6:-3])
print('a[1:6:2]:',a[1:6:2])
5. ndarray类型的算术运算函数
|
函数 |
说明 |
|
np.add(x1, x2 [,y]) |
y = x1 + x2 |
|
np.subtract(x1, x2 [,y]) |
y = x1 - x2 |
|
np.multiply(x1, x2 [,y]) |
y = x1 * x2 |
|
np.divide(x1, x2 [,y]) |
y = x1 / x2 |
|
np.floor_divide(x1, x2 [,y]) |
y = x1 // x2 |
|
np.negative(x [,y]) |
y = -x |
|
np.power(x1, x2 [,y]) |
y = x1 ** x2 |
|
np.remainder(x1, x2 [,y]) |
y = x1 % x2 |
import numpy as np
A1 = np.arange(1,9)
A2 = np.arange(1,30,4) print('A1:',A1)
print('A2:',A2)
print('A2-A1:',np.subtract(A2,A1))
print('A2//A1:',np.floor_divide(A2,A1))
print('A2%A1:',np.remainder(A2,A1))
6. ndarray类型的比较运算函数
|
函数 |
说明 |
|
np.equal(x1, x2 [,y]) |
y = x1 == x2 |
|
np.not_equal(x1, x2 [,y]) |
y = x1 != x2 |
|
np.less(x1, x2 [,y]) |
y = x1 < x2 |
|
np.less_equal(x1, x2 [,y]) |
y = x1 <= x2 |
|
np.greater(x1, x2 [,y]) |
y = x1 > x2 |
|
np.greater_equal(x1, x2 [,y]) |
y = x1 >= x2 |
|
根据条件判断输出x或y |
import numpy as np
A1 = np.arange(1,9)
A2 = np.arange(1,30,4) print('A1:',A1)
print('A2:',A2)
print('A1 != A2:',np.not_equal(A1,A2))
print('A1 <= A2:',np.less_equal(A1,A2))
print('Use of where_1:',np.where(A1>=5,'Y','N'))
print('Usage as much of where:{}'.format('Y' if A1[3]>=5 else 'N'))
7. ndarray类型的其他运算函数
|
函数 |
说明 |
|
np.abs(x) |
返回数组x每个元素的绝对值 |
|
np.sqrt(x) |
返回数组x每个元素的平方根 |
|
np.square(x) |
返回数组x每个元素的平方 |
|
np.sign(x) |
返回数组x每个元素的符号:1(+)、0、-1(-) |
|
np.ceil(x) |
返回大于或等于数组x每个元素的最小值 |
|
np.floor(x) |
返回小于或等于数组x每个元素的最大值 |
|
np.rint(x [,out]) |
返回数组x每个元素最接近的整数 |
|
np.exp(x [,out]) |
返回数组x每个元素的指数值 |
|
np.log(x) / np.log2(x) / np.log10(x) |
返回数组x每个元素相应的对数(e、2、10) |
import numpy as np
A1 = np.arange(1,9)
A2 = np.arange(1,30,4) print('A1:',A1)
print('A2:',A2)
print('A2的平方根:',np.sqrt(A2))
print('A1的平方:',np.sqrt(A1))
print('A2 2的对数:',np.log2(A2))
注:numpy库还包括三角运算函数、傅立叶变换、随机和概率分布、基本数值统计、位运算、矩阵运算等功能,具体可到官网查询。
numpy 库简单使用的更多相关文章
- numpy库简单使用
numpy简介 NumPy(Numerical Python)是python语言的一个扩展程序库,支持大量维度数组与矩阵运算,此外,也针对数据运算提供大量的数学函数库. NumPy是高性能科学计算和数 ...
- numpy 库使用
numpy 库简单使用 一.numpy库简介 Python标准库中提供了一个array类型,用于保存数组类型的数据,然而这个类型不支持多维数据,不适合数值运算.作为Python的第三方库numpy便有 ...
- 简单记录numpy库的某些基本功能
这里介绍python的一个库,numpy库,这个库是机器学习,数据分析最经常用到的库之一,也是利用python做数据必须用到的一个库,入门机器学习学的第一个python库就是它了. 先对其导入到pyt ...
- numpy库:常用基本
numpy 本文主要列出numpy模块常用方法 大部分内容来源于网络,而后经过自己的一点思考和总结,如果有侵权,请联系我 我是一名初学者,有哪些地方有错误请留言,我会及时更改的 创建矩阵(采用ndar ...
- 初识NumPy库-基本操作
ndarray(N-dimensional array)对象是整个numpy库的基础. 它有以下特点: 同质:数组元素的类型和大小相同 定量:数组元素数量是确定的 一.创建简单的数组: np.arra ...
- Numpy库(个人学习笔记)
一样,咱的计算机还是得先拥有Python,并且安装了Numpy库.有疑问的话可以看这里呦~~~~ 下面开讲: NumPy的主要对象是齐次多维数组.它是一个元素表(通常是数字),并且都是相同类型,由正整 ...
- Numpy库的下载及安装(吐血总结)
Python很火,我也下了个来耍耍一阵子.可是渐渐地,我已经不满足于它的基本库了,我把目光转到了Numpy~~~~~ 然而想法总是比现实容易,因为我之前下的是Python3.3.x,所有没有自带pip ...
- Numpy库的学习(五)
今天继续学习一下Numpy库,废话不多说,整起走 先说下Numpy中,经常会犯错的地方,就是数据的复制 这个问题不仅仅是在numpy中有,其他地方也同样会出现 import numpy as np a ...
- Numpy库的学习(一)
今天来学习一下Python库中,支持高级大量的维度数组与矩阵运算的神奇的Numpy库 Numpy同时也对数组运算提供大量的数学函数,对于大量计算运行效率极好 是大量机器学习框架的基础库 废话不多说,直 ...
随机推荐
- linux 下导出oracle数据库
#变更用户su - oracle <<EOF#添加用户名/密码,目标文件地址和文件名 ,保存记录日志地址/文件名 full=y表示数据库全部导出,默认导出连接数据库的用户数据库对象 ex ...
- 关于微博api中发布话题的api问题
https://api.weibo.com/2/statuses/update.json 发布过程中出现的问题 必须在连接加上发布的,access_token,status 例如 https://ap ...
- Freemaker隐藏手机号和判断长度
Freemaker隐藏手机号,用一个取巧的方法. <#if con.phone??> ${con.phone?substring(0,3)}xxxx${con.phone?substrin ...
- fuchsia 内核
1 内核zircon 是c++写的,system call是重写的,不兼容POSIX https://fuchsia.googlesource.com/zircon/+/HEAD/docs/conce ...
- Servlet第二篇(介绍、ServletConfig;ServletContext)
什么是Serlvet? Servlet其实就是一个遵循Servlet开发的java类.Serlvet是由服务器调用的,运行在服务器端. 为什么要用到Serlvet? 我们编写java程序想要在网上实现 ...
- Python学习笔记5程序的控制结构
1.分支结构 (1)单分支结构 (2)二分支结构 (3)多分支结构 条件判断 (4)程序的异常处理 2.实例:身体质量指数BMI 思路一(国内,稍作修改就是国际): 思路二: height,weigh ...
- 4-20arget 属性和hover
1.target 属性 定义和用法 target 属性规定在何处打开 action URL. 值 描述 _blank 在新窗口中打开. _self 默认.在相同的框架中打开. _parent 在父框架 ...
- html模板导出pdf文件
package com.crc.commonreport.util; import java.awt.Insets; import java.io.ByteArrayOutputStream; imp ...
- spark 线性回归算法(scala)
构建Maven项目,托管jar包 数据格式 //0.fp_nid,1.nsr_id,2.gf_id,2.hydm,3.djzclx_dm,4.kydjrq,5.xgrq,6.je,7.se,8.jsh ...
- win10+tensorflow+CUDA 心酸采坑之路
最近准备学习机器学习和深度学习,所以入坑Tensorflow,之前一直使用的是Anaconda3的cpu版本的Tensorflow,但是这次作死一直想用GPU版本的,主要是不想浪费我的1080ti,但 ...