numpy 笔记(1)
numpy基础 笔记
数组的形状
ndarray 的随机创建
# 导入numpy,别名是np
import numpy as np
# 导入matplotlib,别名plt
import matplotlib.pyplot as plt
# random表示常见随机数,rand表示创建一个随机的浮点数数组,参数的个数表示数组维度的大小
# 默认区间是 0.0 ~ 1.0 之间
arr = np.random.rand(3, 4)
print(arr)
print(type(arr))
# ndim 参数表示数组的维度
print(arr.ndim)
# shape 参数表示数据的大小
print(arr.shape)
# reshape 参数表示重塑数据的行列数
# print(arr.reshape(2,6))
# dtype表示每个数据的类型
print(arr.dtype)
输出
[[ 0.22107398 0.71484805 0.8985325 0.1871831 ]
[ 0.40095961 0.18651406 0.85371751 0.38446084]
[ 0.37992371 0.62813441 0.05276292 0.21327295]]
<class ‘numpy.ndarray’>
2
(3, 4)
float64
广播原则
如果两个数组的后缘维度(即从末尾开始算起的维度)的轴长度相符或者其中一方的长度为1,则认为它们是广播兼容的,广播会在缺失和长度为1的维度上进行。
如果是二维的,有一个维度一样便可以计算
shape为(3,3,3)的数组能不够和(3,2)的数组进行计算
shape为(3,3,2)的数组可以和 (3,2)的数组进行计算
可以和在某一个方向shape相同的数组计算
import numpy as np
# 建立一个三维数组
t1 = np.arange(100,124).reshape((2,3,4))
print(t1)
# 将t1换成二维,一维,但是不改变t1的形状
print(t1.reshape(4,6))
print(t1.reshape(24,))
# 下面是二维数据
# print(t1.reshape(1,24))
# print(t1.reshape(24,1))
# 快速换一维
t1.flatten()
# 随机打乱原数组的序列
np.random.shuffle(arr)
# 所有值加2,乘除加减,除以0也会有结果(nan(0/0),inf(无穷大))
print(t1+2)
# t2可以是(2,3),(2,4),(3,4)和一维
t2 = np.arange(8).reshape(2,4)
print(t1-t2)
numpy创建数组
ndarray的序列创建
# lis 是range类型,包含了 0 ~ 10 的数据的迭代器
lis = range(10)
#把 lis 做为np.array()的参数,则会创建一个包含 0 ~10 的10个元素的一维数组
arr = np.array(lis,dtype='i1')
print(arr)
[0 1 2 3 4 5 6 7 8 9]
# array() 参数可以是多维的数组
# 下面示例:表示创建了一个三维数组,数组里包含了两个二维数组,
# 每个二维数组包含了两个一维数组,
# 每个一维数组里包含了10个元素
arr2 = np.array([[lis, lis],[lis, lis]])
print(arr2)
[[[0 1 2 3 4 5 6 7 8 9]
[0 1 2 3 4 5 6 7 8 9]]
,
[[0 1 2 3 4 5 6 7 8 9]
[0 1 2 3 4 5 6 7 8 9]]]
# 创建一个3行4列的二维数组,默认呢数组的每个元素都是float64类型的 0
# 第二个参数可以指定数据类型
arr3 = np.zeros((3, 4), int)
print(arr3)
print(arr3.dtype)
[[0 0 0 0]
[0 0 0 0]
[0 0 0 0]]
int32
# 创建一个3行4列的二维数组,默认数组的每个元素都是float64类型的 1
# 第二个参数可以指定数据类型
arr4= np.ones((3, 4), int)
print(arr4)
[[1 1 1 1]
[1 1 1 1]
[1 1 1 1]]
# 初始化数组,不指定具体数值,里面的值有可能是0,有可能不是0,默认数组的每个元素都是float64类型的
# 第二个参数可以指定数据类型
arr5 = np.empty((3, 4), int)
print(arr5)
[[0 0 0 0]
[0 0 0 0]
[0 0 0 0]]
数组的数据类型转换
zeros_float = np.zeros((3, 4))
print(zeros_float)
[[ 0. 0. 0. 0.]
[ 0. 0. 0. 0.]
[ 0. 0. 0. 0.]]
zeros_int = zeros_float.astype(np.int32)
print(zeros_int)
[[0 0 0 0]
[0 0 0 0]
[0 0 0 0]]
t1 = np.array([random.random() for i in range(10)])
print(t1)
# 保留两位小数
t2 = np.round(t1, 2)
print(t2)
[0.14195446 0.66925828 0.45425019 0.08682404 0.23824718 0.89987356
0.43585148 0.88922967 0.99458272 0.0559437 ]
[0.14 0.67 0.45 0.09 0.24 0.9 0.44 0.89 0.99 0.06]
- Python语言被列入全国计算机等级考试科目中
- WordPress纯代码高仿 无觅相关文章 图文模式功能
- 各种序列化库的性能数据
- WordPress内置搜索结果只有一篇文章时自动跳转到该文章
- Flash/Flex学习笔记(23):运动学原理
- WordPress重定向作者归档链接到“关于”页面
- Flash/Flex学习笔记(25):摩擦力与屏幕环绕
- 搞事情!富士通和微软强强联手用AI加速工作方式转变
- MySQL管理工具HeidiSQL
- Centos 使用YUM安装MariaDB
- Div Scroll Bar (用层模拟滚动条)
- WordPress免插件仅代码实现文章浏览次数的方法(3)
- 定义新智慧,这AI很“远景X3”
- WordPress删除头部wp_head()多余代码
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 「Workshop」第十三期:统计检验与多重矫正
- Linux内核参数调优
- 扒掉“缓冲区溢出”的底裤
- MySQL not exists 真的不走索引么?
- 「R」使用 tinyscholar 展示个人谷歌学术档案
- GC调优到底是什么
- VBA编写Ribbon Custom UI编辑器06——读取xml
- centos安装kubectl和minikube工具
- 性能测试必备命令(4)- pstree
- 你必须熟练使用的10条 Python 技巧
- 四叉树在碰撞检测中的应用
- 一些Redis很实用的工作技巧
- 设计模式(Design Patterns)Java版
- 一个PHP高性能、多并发、restful的工具库(基于multi_curl)
- Spring框架的设计模式