Numpy Quickstart tutorial
此文是关于Numpy的一些基本用法, 内容来源于Numpy官网:https://docs.scipy.org/doc/numpy-dev/user/quickstart.html
1.The Basics
1)导入numpy
import numpy as np
2)创建一个0--14的数组a, 并将其变为3行5列的二位数组
a = np.arange(15).reshape(3, 5)
a
array([[ 0, 1, 2, 3, 4],
[ 5, 6, 7, 8, 9],
[10, 11, 12, 13, 14]])
3)查看a的形状
a.shape
(3, 5)
4)查看a的维数
a.ndim
2
5)查看a中元素的数据类型
a.dtype
dtype('int64')
6)查看数组中每个元素的字节大小
a.itemsize
8
7)查看数组a中所有元素的总个数
a.size
15
8)查看a的类型, 结果显示a是一个numpy数组
type(a)
numpy.ndarray
2.Array Creation
1)可以把一个python列表直接转为numpy数组
a = np.array([2,3,4])
a
array([2, 3, 4])
一个常见的错误是不能直接把元素放入函数小括号内, 需要单独的一个中括号包含着这些元素。
a = np.array(1,2,3,4) # WRONG
---------------------------------------------------------------------------
ValueError Traceback (most recent call last)
<ipython-input-15-90a21e8c09d8> in <module>()
----> 1 a = np.array(1,2,3,4) # WRONG ValueError: only 2 non-keyword arguments accepted a = np.array([1,2,3,4]) # RIGHT
a
array([1, 2, 3, 4])
2)创建元素为0的数组
np.zeros( (3,4) )
array([[ 0., 0., 0., 0.],
[ 0., 0., 0., 0.],
[ 0., 0., 0., 0.]])
3)创建元素为1的数组
np.ones( (2,3,4), dtype=np.int16 )
array([[[1, 1, 1, 1],
[1, 1, 1, 1],
[1, 1, 1, 1]], [[1, 1, 1, 1],
[1, 1, 1, 1],
[1, 1, 1, 1]]], dtype=int16)
4)创建一个空数组
np.empty( (2,3) )
array([[ 0., 0., 0.],
[ 0., 0., 0.]])
5)设定区间, 并按照一定间隔创建数组
np.arange( 10, 30, 5 )
array([10, 15, 20, 25]) np.arange( 0, 2, 0.3 )
array([ 0. , 0.3, 0.6, 0.9, 1.2, 1.5, 1.8])
6)在0到2之间均匀的生成9个数作为数组
from numpy import pi
np.linspace( 0, 2, 9 )
array([ 0. , 0.25, 0.5 , 0.75, 1. , 1.25, 1.5 , 1.75, 2. ])
3.Basic Operations
1)两个数组的元素相加减
a = np.array( [20,30,40,50] )
b = np.arange( 4 )
b
array([0, 1, 2, 3]) c = a-b
c
array([20, 29, 38, 47])
2)数组的2次幂
b**2
array([0, 1, 4, 9]) 10*np.sin(a)
array([ 9.12945251, -9.88031624, 7.4511316 , -2.62374854])
3)对数组内元素与一常量比较大小, 返回一个布尔数组
a<35
array([ True, True, False, False], dtype=bool)
4)两个数组的元素间相乘
A = np.array( [[1,1],[0,1]] )
B = np.array( [[2,0],[3,4]] )
A*B
array([[2, 0],
[0, 4]])
5)两个数组矩阵点乘, 有两种方法, 得到的结果是相同的。
A.dot(B)
array([[5, 4],
[3, 4]]) np.dot(A, B)
array([[5, 4],
[3, 4]])
6)数组的求和、最大值、最小值
a = np.random.random((2,3))
a
array([[ 0.76423426, 0.45623695, 0.65700409],
[ 0.75365929, 0.13244614, 0.23917196]]) a.sum(), a.max(), a.min()
(3.0027526935349194, 0.76423426042527243, 0.13244614149075928)
4.Indexing, Slicing and Iterating
1)一维数组的索引与切片
a = np.arange(10)**3
a
array([ 0, 1, 8, 27, 64, 125, 216, 343, 512, 729]) # a的第三个元素
a[2]
8 # a的第三到第五个元素
a[2:5]
array([ 8, 27, 64]) # a的从0到6个元素中, 索引能被2整除的都替换为-1000
a[:6:2] = -1000
a
array([-1000, 1, -1000, 27, -1000, 125, 216, 343, 512, 729])
# 将a反转
a[ : :-1]
array([ 729, 512, 343, 216, 125, -1000, 27, -1000, 1, -1000])
2)多维数组的索引与切片
def f(x,y):
return 10*x+y b = np.fromfunction(f,(5,4),dtype=int)
b
array([[ 0, 1, 2, 3],
[10, 11, 12, 13],
[20, 21, 22, 23],
[30, 31, 32, 33],
[40, 41, 42, 43]]) b[2,3]
23 b[0:5, 1]
array([ 1, 11, 21, 31, 41])
b[-1]
array([40, 41, 42, 43])
# 将数组展开
b.flatten()、
array([ 0, 1, 2, 3, 10, 11, 12, 13, 20, 21, 22, 23, 30, 31, 32, 33, 40, 41, 42, 43])
3)数组拼接
a = np.floor(10*np.random.random((2,2)))
b = np.floor(10*np.random.random((2,2)))
a
array([[ 4., 7.],
[ 9., 2.]]) b
array([[ 8., 1.],
[ 9., 5.]]) # 竖向拼接
np.vstack((a,b))
array([[ 4., 7.],
[ 9., 2.],
[ 8., 1.],
[ 9., 5.]]) # 横向拼接
np.hstack((a,b))
array([[ 4., 7., 8., 1.],
[ 9., 2., 9., 5.]])
# 横向拼接
np.column_stack((a,b))
array([[ 4., 7., 8., 1.],
[ 9., 2., 9., 5.]])
4) 将数组分成几个小数组
a = np.floor(10*np.random.random((2,12)))
a
array([[ 2., 3., 2., 4., 2., 1., 5., 4., 4., 2., 0., 3.],
[ 9., 2., 0., 2., 8., 3., 6., 2., 7., 2., 2., 6.]]) np.hsplit(a,3) # Split a into 3
[array([[ 2., 3., 2., 4.],
[ 9., 2., 0., 2.]]), array([[ 2., 1., 5., 4.],
[ 8., 3., 6., 2.]]), array([[ 4., 2., 0., 3.],
[ 7., 2., 2., 6.]])] np.hsplit(a,(3,4)) # Split a after the third and the fourth column
[array([[ 2., 3., 2.],
[ 9., 2., 0.]]), array([[ 4.],
[ 2.]]), array([[ 2., 1., 5., 4., 4., 2., 0., 3.],
[ 8., 3., 6., 2., 7., 2., 2., 6.]])]
Numpy Quickstart tutorial的更多相关文章
- Python 学习 第十一篇:numpy
numpy是Python中的基础模块,类型ndarray定义了一个具有矢量算术运算的多维数组,无需编写循环,就能对整个数组进行批量运算.通常情况下,导入numpy,设置别名为np. import nu ...
- numpy 学习笔记
numpy 学习笔记 导入 numpy 包 import numpy as np 声明 ndarray 的几种方法 方法一,从list中创建 l = [[1,2,3], [4,5,6], [7,8,9 ...
- [Python] 01 - Number
故事背景 一.大纲 如下,chapter4 是个概览,之后才是具体讲解. 二. 编译过程 Ref: http://www.dsf.unica.it/~fiore/LearningPython.pdf
- [Python] 01 - Number and Matrix
故事背景 一.大纲 如下,chapter4 是个概览,之后才是具体讲解. 二. 编译过程 Ref: http://www.dsf.unica.it/~fiore/LearningPython.pdf
- 小猪的Python学习之旅 —— 16.再尝Python数据分析:采集拉勾网数据分析Android就业行情...
一句话概括本文: 爬取拉钩Android职位相关数据,利用numpy,pandas和matplotlib对招人公司 情况和招聘要求进行数据分析. 引言: 在写完上一篇<浅尝Python数据分析: ...
- numpy基本用法
numpy 简介 numpy的存在使得python拥有强大的矩阵计算能力,不亚于matlab. 官方文档(https://docs.scipy.org/doc/numpy-dev/user/quick ...
- numpy快速指南
Quickstart tutorial 引用https://docs.scipy.org/doc/numpy-dev/user/quickstart.html Prerequisites Before ...
- Mac 操作系统安装 SVN server教程(Subversion With Mac OS X Tutorial)
Find recent articles on my github page: rubyrobot.github.io © 2006-2014 Imagine Ecommerce Subversion ...
- Python数据分析与可视化(经典学习资料)
Numpy:来存储和处理大型矩阵,比Python自身的嵌套列表(nested list structure)结构要高效的多,本身是由C语言开发.这个是很基础的扩展,其余的扩展都是以此为基础.数据结构为 ...
随机推荐
- 【Linux】make编译的小技巧
------------------------------------------------------------------------------------------------- | ...
- STM32F207时钟系统解析
在前几天的文章<晶振原理解析>中介绍了晶振如何产生时钟的,板子使用的是25M无源晶振,下文将介绍STM32F207的时钟系统如何将25M晶振时钟转换为120M系统主频时钟的. 01.时钟系 ...
- 网络可视化工具netron详细安装流程
1.netron 简介 在实际的项目中,经过会遇到各种网络模型,需要我们快速去了解网络结构.如果单纯的去看模型文件,脑海中很难直观的浮现网络的架构. 这时,就可以使用netron可视化工具,可以清晰的 ...
- 飞机大战(1)--添加logo和加载动画
注:以下代码都是用scratch 3.0版本编写 素材链接: 链接:https://pan.baidu.com/s/1sXqeZVuFgVTYT0OtqxXilw 提取码:1126 一.背景添加 导入 ...
- C#高级编程第11版 - 第九章 索引
[1]9.1 System.String 类 String类中关键的方法.如替换,比较等. [2]9.1.1 构建字符串 1.String类依然有一个缺点:因为它是不可变的数据类型,这意味当你初始化一 ...
- Bitter.Core系列六:Bitter ORM NETCORE ORM 全网最粗暴简单易用高性能的 NETCore ORM 之 示例 DataTable 模型转换
当我们查询之前,我们先构造一个查询对象的输出DTO.如下图代码: public class TScoreSearchDto { /// <summary> /// 分数 /// </ ...
- Hash Join: Basic Steps
Joins https://docs.oracle.com/database/121/TGSQL/tgsql_join.htm#TGSQL242 tidb/index_lookup_hash_join ...
- Redis击穿、穿透、雪崩产生原因以及解决思路
击穿 大家都知道,计算机的瓶颈之一就是IO,为了解决内存与磁盘速度不匹配的问题,产生了缓存,将一些热点数据放在内存中,随用随取,降低连接到数据库的请求链接,避免数据库挂掉.需要注意的是,无论是击穿还是 ...
- 数据湖-Apache Hudi
Hudi特性 数据湖处理非结构化数据.日志数据.结构化数据 支持较快upsert/delete, 可插入索引 Table Schema 小文件管理Compaction ACID语义保证,多版本保证 并 ...
- noip 注意事项 (个人向)
目录 非常重要 对拍 空间 极限数据 模数,YES/NO等大小写 个人 考场 神仙 czdzx 说要写,我也来写 非常重要 对拍 空间 极限数据 模数,YES/NO等大小写 个人 养身体,不要紧张,不 ...