Numpy 数据类型

bool 用一位存储的布尔类型(值为TRUE或FALSE)
inti 由所在平台决定其精度的整数(一般为int32或int64)
int8 整数,范围为128至127
int16 整数,范围为32 768至32 767
int32 整数,范围为231至231 1
int64 整数,范围为263至263 1
uint8 无符号整数,范围为0至255
uint16 无符号整数,范围为0至65 535
uint32 无符号整数,范围为0至2321
uint64 无符号整数,范围为0至2641
float16 半精度浮点数(16位):其中用1位表示正负号,5位表示指数,10位表示尾数
float32 单精度浮点数(32位):其中用1位表示正负号,8位表示指数,23位表示尾数
float64或float 双精度浮点数(64位):其中用1位表示正负号,11位表示指数,52位表示尾数
complex64 复数,分别用两个32位浮点数表示实部和虚部
complex128或complex 复数,分别用两个64位浮点数表示实部和虚部

一维数组的索引和切片

import numpy as np
d = np.arange(9)
print (d)
# [0 1 2 3 4 5 6 7 8]
print (d[2:4]) # 获取2~4 之间的元素
# [2 3]
print (d[::-1]) # 负数下标翻转数组
# [8 7 6 5 4 3 2 1 0]

# 改变数组的维度
# reshape 改变数组维度(重新调整矩阵的行数、列数、维数。)

import numpy as np
e = np.arange(9)
print (e)
# [0 1 2 3 4 5 6 7 8]
e1 = e.reshape(3,3) #
print (e1)
#[[0 1 2]
# [3 4 5]
# [6 7 8]]

ravel函数完成展平

import numpy as np
f = np.arange(24).reshape(2,3,4)
print (f)
#[[[ 0 1 2 3]
# [ 4 5 6 7]
# [ 8 9 10 11]]
#
# [[12 13 14 15]
# [16 17 18 19]
# [20 21 22 23]]]
f1 = f.ravel()
print (f1)
#[ 0 1 2 ..., 21 22 23]

flatten 这个函数恰如其名,flatten就是展平的意思,与ravel函数的功能相同。不过,flatten函数会请求分配内存来保存结果,而ravel函数只是返回数组的一个视图(view)

f2 = f.flatten()
print (f2)
#[ 0 1 2 ..., 21 22 23]

shape,用元组设置维度

f.shape=(6,4)
print (f)
#[[ 0 1 2 3]
# [ 4 5 6 7]
# [ 8 9 10 11]
# [12 13 14 15]
# [16 17 18 19]
# [20 21 22 23]]

resize,resize和reshape函数的功能一样,但resize会直接修改所操作的数组:

f.resize((2,12))
print (f)
#[[ 0 1 2 ..., 9 10 11]
# [12 13 14 ..., 21 22 23]]

数组的组合

import numpy as np
a = np.arange(9).reshape(3,3)
print (a)
#[[0 1 2]
# [3 4 5]
# [6 7 8]]
b = 2 * a
print (b)
#[[ 0 2 4]
# [ 6 8 10]
# [12 14 16]]

# 1. 水平组合hstack函数

h = np.hstack((a,b))
print (h)
#[[ 0 1 2 0 2 4]
# [ 3 4 5 6 8 10]
# [ 6 7 8 12 14 16]]

# 2. 垂直组合vstack函数

v = np.vstack((a,b))
print (v)
#[[ 0 1 2]
# [ 3 4 5]
# [ 6 7 8]
# [ 0 2 4]
# [ 6 8 10]
# [12 14 16]]

# 3. 深度组合dstack函数(将一系列数组沿着纵轴(深度)方向进行层叠组合)

d = np.dstack((a,b))
print (d)
#[[[ 0 0]
# [ 1 2]
# [ 2 4]]
#
# [[ 3 6]
# [ 4 8]
# [ 5 10]]
#
# [[ 6 12]
# [ 7 14]
# [ 8 16]]]

# 4. 列组合,column_stack函数对于一维数组将按列方向进行组合,对于二维数组,column_stack与hstack的效果是相同

c = np.arange(5)
c1 = 2 * c
c2 = np.column_stack((c,c1))
print (c2)
#[[0 0]
# [1 2]
# [2 4]
# [3 6]
# [4 8]] l = np.column_stack((a,b))
print (l)
#[[ 0 1 2 0 2 4]
# [ 3 4 5 6 8 10]
# [ 6 7 8 12 14 16]]

# 行组合row_stack函数(对于两个一维数组,将直接层叠起来组合成一个二维数组,对于二维数组,row_stack与vstack的效果是相同的)

c = np.arange(5)
c1 = 2 * c
c3 = np.row_stack((c,c1))
print (c3)
#[[0 1 2 3 4]
# [0 2 4 6 8]] r = np.row_stack((a,b))
print (r)
#[[ 0 1 2]
# [ 3 4 5]
# [ 6 7 8]
# [ 0 2 4]
# [ 6 8 10]
# [12 14 16]]

# 分割数组

A = np.arange(9).reshape(3,3)
print (A)
#[[0 1 2]
# [3 4 5]
# [6 7 8]]

# 1. 水平分割 hsplit函数

H = np.hsplit(A,3)
print (H)
#[array([[0],
# [3],
# [6]]), array([[1],
# [4],
# [7]]), array([[2],
# [5],
# [8]])]

# 调用split函数并指定参数axis=1

H1 =np.split(A,3,axis=1)
print (H1)
#[array([[0],
# [3],
# [6]]), array([[1],
# [4],
# [7]]), array([[2],
# [5],
# [8]])]

# 2. 垂直分割,vsplit函数

V = np.vsplit(a,3)
print (V)
#[array([[0, 1, 2]]), array([[3, 4, 5]]), array([[6, 7, 8]])]

# 调用split函数并指定参数axis=0

V1 = np.split(A,3,axis=0)
print (V1)
#[array([[0, 1, 2]]), array([[3, 4, 5]]), array([[6, 7, 8]])]

# 3. 深度分割,dsplit函数

C = np.arange(27).reshape(3,3,3)
print (C)
#[[[ 0 1 2]
# [ 3 4 5]
# [ 6 7 8]]
#
# [[ 9 10 11]
# [12 13 14]
# [15 16 17]]
#
# [[18 19 20]
# [21 22 23]
# [24 25 26]]]
D = np.dsplit(C,3)
print (D)
#[array([[[ 0],
# [ 3],
# [ 6]],
#
# [[ 9],
# [12],
# [15]],
#
# [[18],
# [21],
# [24]]]), array([[[ 1],
# [ 4],
# [ 7]],
#
# [[10],
# [13],
# [16]],
#
# [[19],
# [22],
# [25]]]), array([[[ 2],
# [ 5],
# [ 8]],
#
# [[11],
# [14],
# [17]],
#
# [[20],
# [23],
# [26]]])]

# 数组的属性

num = np.arange(24).reshape(2,12)
print (num)
#[[ 0 1 2 ..., 9 10 11]
# [12 13 14 ..., 21 22 23]]

# 1. ndim属性,给出数组的维数,或数组轴的个数

print (num.ndim)
#2

# 2. size属性,给出数组元素的总个数

print (num.size)
#24

# 3. itemsize属性,给出数组中的元素在内存中所占的字节数

print (num.itemsize)
#4

# 4. nbytes属性,整个数组所占的存储空间(itemsize和size属性值的乘积)

print (num.nbytes)
#96

# 5. T属性,效果和transpose函数一样

# 数组的转换,tolist函数

Numpy 数据类型和基本操作的更多相关文章

  1. NumPy数据类型

    NumPy - 数据类型 NumPy 支持比 Python 更多种类的数值类型. 下表显示了 NumPy 中定义的不同标量数据类型. 序号 数据类型及描述 1. bool_存储为一个字节的布尔值(真或 ...

  2. numpy 数据类型与 Python 原生数据类型

    查看 numpy 数据类型和 Python 原生数据类型之间的对应关系: In [51]: dict([(d, type(np.zeros(1,d).tolist()[0])) for d in (n ...

  3. Redis数据类型的基本操作

    Redis数据类型的基本操作 一.string类型 1.设置value

  4. 2、NumPy 数据类型

    1.NumPy 数据类型 numpy 支持的数据类型比 Python 内置的类型要多很多,基本上可以和 C 语言的数据类型对应上,其中部分类型对应为 Python 内置的类型.下表列举了常用 NumP ...

  5. Lesson3——NumPy 数据类型

    NumPy 教程目录 NumPy 数据类型 numpy 支持的数据类型比 Python 内置的类型要多很多,基本上可以和 C 语言的数据类型对应上,其中部分类型对应为 Python 内置的类型. 下表 ...

  6. Redis 学习笔记-5种数据类型的基本操作

    1.string类型 基本操作列表: GET 获取指定键对应的值 SET 设定键值 DEL 删除指定键对应的值(对所有数据类型都有效) > set hello world OK > get ...

  7. Numpy 数据类型

    numpy支持的数据类型比Python内置的类型多很多,基本上可以和C语言的数据类型对应上, 其中部分类型对应为Python内置的类型.下表列举了常用的Numpy基本类型. 名称 描述 bool_ 布 ...

  8. MYSQL数据类型 表基本操作 表记录增删改 单表查询

    一.数据类型 常用的数据类型如下: 整数:int,bit 小数:decimal 字符串:varchar,char 日期时间: date, time, datetime 枚举类型(enum) 特别说明的 ...

  9. Numpy数据类型转化astype,dtype

    1. 查看数据类型 import numpy as np arr = np.array([1,2,3,4,5]) print(arr) [1 2 3 4 5] # dtype用来查看数据类型 arr. ...

随机推荐

  1. saltstack通过jinja模板,将变量值增加到配置文件中?通过引用变量值修改配置文件?

    需求描述: 在使用saltstack的时候,有的时候,需要根据不同的变量来增加配置,比如,bind,监听端口,这些都可以通过变量写入,并且在配置的时候引用,下面是一个例子,用来演示,如何使用jinja ...

  2. dos 打开计算机管理

    一. 首先打开[运行]程序:二. 运行中输入‘CMD’:三. 然后在上面输入‘compmgmt.msc’,就可以打开“计算机管理”命令了.

  3. is not in the sudoers file解决方法

    用sudo时提示"xxx is not in the sudoers file. This incident will be reported.其中XXX是你的用户名,也就是你的用户名没有权 ...

  4. google的python语言规范

    Python语言规范   Lint Tip 对你的代码运行pylint 定义: pylint是一个在Python源代码中查找bug的工具. 对于C和C++这样的不那么动态的(译者注: 原文是less ...

  5. unity 5.3 以后加载场景

    记录下官方建议的加载场景的方法: StartCoroutine(LoadYourAsyncScene()); IEnumerator LoadYourAsyncScene() { // The App ...

  6. windows安装mysql8

    1:首先去官网下载安装包 下载地址:https://dev.mysql.com/downloads/mysql/ 2:将解压文件解压到你安装的目录:E:\mysql-8.0.11-winx64  (我 ...

  7. TensorFlow环境 人脸识别 FaceNet 应用(一)验证测试集

    TensorFlow环境 人脸识别 FaceNet 应用(一)验证测试集 前提是TensorFlow环境以及相关的依赖环境已经安装,可以正常运行. 一.下载FaceNet源代码工程 git clone ...

  8. python基础类型—元祖

    元组  被称为只读列表,即数据可以被查询,但不能被修改,所以,字符串的切片操作同样适用于元组. 例:(1,2,3)("a","b","c") ...

  9. 浅谈提高Django性能

    Django性能优化是一件困难的事情,但是也不常常如此: 下面4步将能够轻松的提高你的网站的性能,它们非常简单你应该将它们 作为标配. 持久化数据库连接 django1.6以后已经内置了数据库持久化连 ...

  10. poi导入excel表格数据到数据库的时候,对出生日期的校验

    出生日期格式为8位数字的字符串 如:yyyyMMdd 规则:yyyy大于1900并小于当前时间,月.日 按日期规则校验 //解决读过来的字符串显示为科学计数法问题 BigDecimal bd = ne ...