Numpy介绍:

NumPy是高性能科学计算和数据分析的基础包。它是pandas等其他各种工具的基础。

NumPy的主要功能:
  1)ndarray,一个多维数组结构,高效且节省空间
  2)无需循环对整组数据进行快速运算的数学函数
  3)读写磁盘数据的工具以及用于操作内存映射文件的工具
  4)线性代数、随机数生成和傅里叶变换功能
  5)用于集成C、C++等代码的工具

pyhton里面安装、引入方式:
  安装方法:pip install numpy
  引用方式:import numpy as np

 创建数组:

a=[1,2,3,4]
b=np.array(a) print(b,type(b)) #[1 2 3 4] <class 'numpy.ndarray'>

数组属性:

#数组个数
print(b.size) #
#数组形状
print(b.shape) #(4,)
#每个元素占用你的字节数
print(b.itemsize) #
#维数
print(b.ndim) #

arange定义一个数组,限定步长:

np.arange() 参数为初始值、结束值(不包含)、步长
array_arange=np.arange(10,30,5)
print(array_arange) #[10 15 20 25]

linspace定义一个数组,限定数组元素的个数:

np.linspace() 数为初始值、结束值(包含)、元素的个数,
array_linspace=np.linspace(0,2,9) #结果第一位是0 中间数值平均分配 结束为2
print(array_linspace) #[0. 0.25 0.5 0.75 1. 1.25 1.5 1.75 2. ]

快速创建N维数组:

ones,创建10行10列的数值为浮点1的矩阵

array_one=np.ones((5,5),dtype=int)  #dtype=int 可以设置类型
print(array_one)

zeros,创建10行10列的数值为浮点0的矩阵

array_zero=np.zeros((2,5,5))        #array_zero=np.zeros((2,5,5)) 2:表示创建2个5行5列的数组
print(array_zero)

创建自定义数值的数组:

full,创建3*3 数值为5的数组

full_array=np.full((3,3),5)
print(full_array)

eye,用来构造单位矩阵(默认情况下输出的是对角线全“1”,其余全“0”的方阵

eye_array=np.eye(3)
print(eye_array) '''结果
[[1. 0. 0.]
[0. 1. 0.]
[0. 0. 1.]] '''

empty,生成未初始化的随机值

empty_array=np.empty((2,4))
print(empty_array) '''结果为
[[6.23042183e-307 1.42417221e-306 1.37961641e-306 6.23039015e-307]
[6.23053954e-307 1.78020169e-306 1.78021527e-306 3.91786943e-317]] ''' 

random生成随机数组\数值

random.rand(),2*2 (范围是0-1)

array_random=np.random.rand(2,2)
print(array_random)

random.uniform(),随机生成指定范围内的一个数(小数)

array_uniform=np.random.uniform(0,5)
print(array_uniform) #0.6259318369377503

random.randint(),随机生成指定范围内的一个数(整数不包含2)

array_randint=np.random.randint(0,2)
print(array_randint) #

正太分布
给定均值/标准差/维度的正态分布np.random.normal(1.75, 0.1, (2, 3))

#正态生成4行5列的二维数组
arr=np.random.normal(1.75,0.1,(4,5))
print(arr) #截取第1至2行的第2至3列(从第0行算起)
after_arr=arr[1:3,2:4] #【参数1,参数2】 参数1取的行 参数2取的是范围
print(after_arr) # '''结果
[[1.7121083 1.79442264 1.88480996 1.74680449 1.94296451]
[1.75145398 1.84717094 1.61700579 1.79300659 1.65306822]
[1.84915626 1.82844994 1.42992838 1.74578747 1.81638628]
[1.78611223 1.79935389 1.71098421 1.7065452 1.93011894]] [[1.61700579 1.79300659]
[1.42992838 1.74578747]]
'''

reshape,改变数组形状(注意:要求前后元素个数匹配)

one_20 = np.ones([20])
print("-->1行20列<--")
print(one_20) #将上面的一维数组变为下面的二维 one_4_5 = one_20.reshape([4,5])
print("将形状分为-->4行5列<--")
print(one_4_5)

where,条件运算

stus_score = np.array([[80, 88], [82, 81], [84, 75], [86, 83], [75, 81]])
print(stus_score)
#比较并替换运算
res=np.where(stus_score<80,0,90) #(如果数值小于80,替换为0,如果大于80,替换为90)
print(res)

统计运算

指定轴最大值amax(求每一行和列的最大值)

# 指定轴最大值amax(求每一行和列的最大值)
stus_score=np.array([[80, 88], [82, 81], [84, 75], [86, 83], [75, 81]])
print(stus_score) result_amax=np.amax(stus_score,axis=0) #axis=0/1; 0表示列 1表示行
print('每一列的最大值:',result_amax) #[86 88] result_amax2=np.amax(stus_score,axis=1)
print('每一行的最大值:',result_amax2) #[88 82 84 86 81]

指定轴最小值amin(求每一行和列的最小值)

#指定轴最小值amin(求每一行和列的最小值)
stus_score=np.array([[80, 88], [82, 81], [84, 75], [86, 83], [75, 81]])
print(stus_score)
result_amin=np.amin(stus_score,axis=0)
print('每一列的最小值:',result_amin) result_amin2=np.amin(stus_score,axis=1) #[75 75]
print('每一列的最小值:',result_amin2) #[80 81 75 83 75]

mean,求平均值

stus_score = np.array([[80, 88], [82, 81], [84, 75], [86, 83], [75, 81]])

# 求每一行的平均值(0表示列)
print("每一列的平均值:")
result = np.mean(stus_score, axis=0)
print(result) #[81.4 81.6] # 求每一行的平均值(1表示行)
print("每一行的平均值:")
result = np.mean(stus_score, axis=1)
print(result) #[84. 81.5 79.5 84.5 78. ]

std,求方差

stus_score = np.array([[80, 88], [82, 81], [84, 75], [86, 83], [75, 81]])

# 求每一行的方差(0表示列)
print("每一列的方差:")
result = np.std(stus_score, axis=0)
print(result) # 求每一行的方差(1表示行)
print("每一行的方差:")
result = np.std(stus_score, axis=1)
print(result)

数组运算

数组与数的运算

加法运算

#数组与数的运算(加法)
stus_score=np.array(([80, 88], [82, 81], [84, 75], [86, 83], [75, 81]))
print(stus_score)
print(stus_score[:,0]) #[80 82 84 86 75] 打印第一列的值
#实现行和列的值都加5
stus_score[:,0] = stus_score[:,0]+5 #每一列值加5
stus_score[:,1] = stus_score[:,1]+5 #每一行值加5
print(stus_score)

乘法运算

#数组与数的运算(乘法)
stus_score = np.array([[80, 88], [82, 81], [84, 75], [86, 83], [75, 81]])
print("减半前:")
print(stus_score)
#实现行和列的值都减一半
stus_score[:, 0] = stus_score[:, 0]*0.5 #每一列乘0.5
stus_score[:, 0] = stus_score[:, 1]*0.5 #每一行乘0.5
print("减半后:")
print(stus_score)

数组与数组之间运算加减乘除运算(基本用的不多)

a=np.array([1,2,3])
b=np.array([10,20,30]) c=a+b
d=a-b
e=a*b
f=a/b
print(c) #[11 22 33]
print(d) #[ -9 -18 -27]
print(e) #[10 40 90]
print(f) #[0.1 0.1 0.1]

矩阵运算

场景:假设下面每个列表代表每个学生成绩,例如,张三 平时成绩80、期末成绩88,计算每个人总成绩是多少?
stus_score = np.array([[80, 88], [82, 81], [84, 75], [86, 83], [75, 81]]) #根据,平时成绩占40% 期末成绩占60%, 计算结果
q=np.array([[0.4],[0.6]])
result=np.dot(stus_score,q)
print(result) '''结果
E:\python36\python3.exe C:/Python数据分析/numpy模块.py
[[84.8]
[81.4]
[78.6]
[84.2]
[78.6]]
'''

vstack矩阵垂直拼接

#vstack矩阵垂直拼接
v1=[[0,1,2,3,4,5,],
[6,7,8,9,10,11]] v2=[[12, 13, 14, 15, 16, 17],
[18, 19, 20, 21, 22, 23]] result=np.vstack((v1,v2))
print('v1与v2垂直拼接结果为:',result)
'''结果
[[ 0 1 2 3 4 5]
[ 6 7 8 9 10 11]
[12 13 14 15 16 17]
[18 19 20 21 22 23]] '''

hstack矩阵水平拼接

#hstack矩阵水平拼接
v1=[[0,1,2,3,4,5,],
[6,7,8,9,10,11]] v2=[[12, 13, 14, 15, 16, 17],
[18, 19, 20, 21, 22, 23]]
result=np.hstack((v1,v2))
print('v1与v2水平拼接结果为:',result)
'''结果
[[ 0 1 2 3 4 5 12 13 14 15 16 17]
[ 6 7 8 9 10 11 18 19 20 21 22 23]]

练习题目:

题目1:对一个二维数组,选出其第一列和第二列,组成新的二维数组。

res=np.array(([1,2,3],[4,5,6],[7,8,9]))
print(res)
print(res[:,[1,2]]) #思路第一个参数时表示去所有行,近一步然后取第1,2列
'''结果为
[[1 2 3]
[4 5 6]
[7 8 9]]
[[2 3]
[5 6]
[8 9]] '''

题目2:对于一个数组,选出其第1,3,4,6,7个元素,组成新的二维数组。

res=np.array([1,2,3,4,5,6,7,8,9])
print(res[[1,3,4,6,7]])

Python数据分析-Numpy数值计算的更多相关文章

  1. python数据分析Numpy(二)

    Numpy (Numerical Python) 高性能科学计算和数据分析的基础包: ndarray,多维数组(矩阵),具有矢量运算能力,快速.节省空间: 矩阵运算,无需循环,可以完成类似Matlab ...

  2. Python数据分析——numpy基础简介

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者:基因学苑 NumPy(Numerical Python的简称)是高性 ...

  3. python数据分析 Numpy基础 数组和矢量计算

    NumPy(Numerical Python的简称)是Python数值计算最重要的基础包.大多数提供科学计算的包都是用NumPy的数组作为构建基础. NumPy的部分功能如下: ndarray,一个具 ...

  4. Python数据分析numpy库

    1.简介 Numpy库是进行数据分析的基础库,panda库就是基于Numpy库的,在计算多维数组与大型数组方面使用最广,还提供多个函数操作起来效率也高 2.Numpy库的安装 linux(Ubuntu ...

  5. python 数据分析----numpy

    NumPy是高性能科学计算和数据分析的基础包.它是pandas等其他各种工具的基础. NumPy的主要功能: ndarray,一个多维数组结构,高效且节省空间 无需循环对整组数据进行快速运算的数学函数 ...

  6. Python数据分析 | Numpy与1维数组操作

    作者:韩信子@ShowMeAI 教程地址:http://www.showmeai.tech/tutorials/33 本文地址:http://www.showmeai.tech/article-det ...

  7. Python数据分析Numpy库方法简介(二)

    数据分析图片保存:vg 1.保存图片:plt.savefig(path) 2.图片格式:jpg,png,svg(建议使用,不失真) 3.数据存储格式: excle,csv csv介绍 csv就是用逗号 ...

  8. Python数据分析--Numpy常用函数介绍(2)

    摘要:本篇我们将以分析历史股价为例,介绍怎样从文件中载入数据,以及怎样使用NumPy的基本数学和统计分析函数.学习读写文件的方法,并尝试函数式编程和NumPy线性代数运算,来学习NumPy的常用函数. ...

  9. Python数据分析--Numpy常用函数介绍(6)--Numpy中矩阵和通用函数

    在NumPy中,矩阵是 ndarray 的子类,与数学概念中的矩阵一样,NumPy中的矩阵也是二维的,可以使用 mat . matrix 以及 bmat 函数来创建矩阵. 一.创建矩阵 mat 函数创 ...

随机推荐

  1. [ difflib] simple1.py

    #!/usr/bin/env python # _*_ coding:utf-8 _*_ import difflib text1 = """text1: # 定义字符串 ...

  2. 【书籍连载】《STM32 HAL 库开发实战指南—基于F7》-第一章

    从今天起,每天开始连载一章<STM32 HAL 库开发实战指南—基于F7>.欢迎各位阅读.点评.学习. 第1章  如何使用本书 1.1  本书的参考资料 本书参考资料为:<STM32 ...

  3. vue项目不能同时被localhost和ip地址同时访问的方法

    方法1.将index.js中的host的值改为‘0.0.0.0’ 方法2.修改package.json中script下dev的值,在后面加入--host 0.0.0.0 也可以解决

  4. mybatis两级缓存原理剖析

    https://blog.csdn.net/zhurhyme/article/details/81064108 对于mybatis的缓存认识一直有一个误区,所以今天写一篇文章帮自己订正一下.mybat ...

  5. LArea 微信端 地址选择

    最近做到一个项目,微信端的商城需要地址选择功能 在百度上看了,采用LArea.js....下载实例,在移动端模拟器上运行是比较好的, 在微信上模拟后出现很多问题, 1,出现undefined 都定义正 ...

  6. IDEA的下载安装和激活

    1.下载网站http://www.jetbrains.com/ 2. 3. 4.注意要下载Ultimate版本 5.安装 下载完成后直接下一步,傻瓜式安装 6.激活,在图片位置输入激活码即可 !!!! ...

  7. Pandas基本命令

    关键缩写和包导入 在这个速查手册中,我们使用如下缩写: df:任意的Pandas DataFrame对象 同时我们需要做如下的引入: import pandas as pd 创建测试对象 import ...

  8. Android面试收集录10 LruCache原理解析

    一.Android中的缓存策略 一般来说,缓存策略主要包含缓存的添加.获取和删除这三类操作.如何添加和获取缓存这个比较好理解,那么为什么还要删除缓存呢?这是因为不管是内存缓存还是硬盘缓存,它们的缓存大 ...

  9. saltstack执行远程命令

    目录 Remote Execution salt state salt state 系统 salt state 系统流程 Runner salt runner Orchestrate Runner S ...

  10. fromkeys语法/set集合/深浅拷贝/列表/字典的删除

    fromkeys语法: dic = {"apple":"苹果", "banana":"香蕉"} 返回新字典. 和原来的没 ...