以下代码来源于本博文作者观看大神视频并纯手敲。

目录

numpy的属性

创建array

numpy的运算1

随机数生成以及矩阵的运算2

numpy的索引

array合并

array分割

numpy的浅拷贝和深拷贝

numpy的属性

import numpy as np

array = np.array([[1, 2, 3], [4, 5, 6], [7, 8, 9]])
print(array)
print(array.ndim) # 维度 2
print(array.shape) # 形状 (3, 3)
print(array.size) # 大小 9
print(array.dtype) # 元素类型 int32

numpy创建array

import numpy as np

a = np.array([1, 2, 3], dtype=np.int32)
print(a.dtype) # int32
b = np.array([1, 2, 3], dtype=np.float)
print(b.dtype) # float64
c = np.array([1, 2, 3])
d = np.array([[1, 2, 3], [4, 5, 6]])
print(d) # 二维矩阵
zero = np.zeros((2, 3))
print(zero) # 生成两行三列全为零的矩阵
one = np.ones((3, 4))
print(one) # 生成三行四列全为1的矩阵
empty = np.empty((3, 2))
print(empty) # 生成三行两列全都接近于零的矩阵(但不等于0)
e = np.arange(10)
print(e)
f = np.arange(4, 12)
print(f) # [ 4 5 6 7 8 9 10 11]
g = np.arange(1, 20, 3)
print(g)
h = np.arange(8).reshape(2, 4)
print(h) # 重新定义矩阵形状

numpy矩阵的运算

import numpy as np

arr1 = np.array([[1, 2, 3], [4, 5, 6]])
arr2 = np.array([[1, 1, 2], [2, 3, 3]])
print(arr1 + arr2) # 按照位置相加
print(arr1 - arr2)
print(arr1 * arr2)
print(arr1 ** arr2)
print(arr1 / arr2)
print(arr1 % arr2)
print(arr1 // arr2)
print(arr1 + 2) # 所有的元素都加2
arr3 = arr1 > 3
print(arr3) # 判断哪些元素大于3
arr4 = np.ones((3, 5))
print(arr4)
print(arr1)
res = np.dot(arr1, arr4) # 矩阵的乘法
print(res)
res1 = arr1.dot(arr4) # 矩阵的乘法
print(res1)
print(arr1.T) # 转置矩阵
print(np.transpose(arr1)) # 转置矩阵

随机数生成以及矩阵的运算2

import numpy as np

sample1 = np.random.random((3, 2))  # 生成3行2列的从0到1的随机数
print(sample1)
sample2 = np.random.normal(size=(3, 2)) # 生成3行2列符合标准正太分布的随机数
print(sample2)
sample3 = np.random.randint(0, 10, size=(3, 2)) # 生成3行2列的从0-10的随机整数
print(sample3)
print(np.sum(sample1)) # 求和
print(np.min(sample1)) # 求最小值
print(np.sum(sample1, axis=0)) # 对每一列进行求和
print(np.sum(sample1, axis=1)) # 对每一行进行求和
print(np.argmin(sample1)) # 求最小值的索引
print(np.argmax(sample1)) # 求最大值的索引
print(np.mean(sample1)) # 求平均值
print(sample1.mean()) # 求平均值
print(np.median(sample1)) # 求中位数
print(np.sqrt(sample1)) # 开方
sample4 = np.random.randint(0, 10, size=(1, 10))
print(sample4)
print(np.sort(sample4)) # 排序:按行升序
print(np.sort(sample1))
print(np.clip(sample4, 2, 7)) # 小于2的变成2,大于7的变成7

numpy的索引

import numpy as np

arr1 = np.arange(2, 14)
print(arr1) # [ 2 3 4 5 6 7 8 9 10 11 12 13]
print(arr1[2]) # 4
print(arr1[1: 4]) # [3 4 5]
print(arr1[2: -1]) # [ 4 5 6 7 8 9 10 11 12]
print(arr1[: 5]) # [2 3 4 5 6]
print(arr1[-2:]) # [12 13]
arr2 = arr1.reshape(3, 4)
print(arr2) #
print(arr2[1]) # [6 7 8 9]
print(arr2[1][1]) # 7
print(arr2[1, 2]) # 8
print(arr2[:, 2]) # [ 4 8 12] 所有行,第2列
for i in arr2: # 迭代行
print(i)
for i in arr2.T: # 迭代列
print(i)
for i in arr2.flat: # 迭代一个个元素
print(i)

array的合并

import numpy as np

arr1 = np.array([1, 2, 3])
arr2 = np.array([4, 5, 6])
arr3 = np.vstack((arr1, arr2)) # 垂直合并
print(arr3)
print(arr3.shape)
arr4 = np.hstack((arr1, arr2)) # 水平合并
print(arr4) # [1 2 3 4 5 6]
print(arr4.shape)
arrv = np.vstack((arr1, arr2, arr3))
print(arrv)
arrh = np.hstack((arr1, arr2, arr4))
print(arrh)
arr = np.concatenate((arr1, arr2, arr1)) # 合并
print(arr)
arr = np.concatenate((arr3, arrv), axis=0) # 垂直合并。合并的array维度要相同,array形状要匹配,axis=0纵向合并
print(arr)
arr = np.concatenate((arr3, arr3), axis=1) # 水平合并
print(arr)
print(arr1.T) # 一维的array不能转置
print(arr1.shape) # (3,)
arr1_1 = arr1[np.newaxis, :]
print(arr1_1) # [[1 2 3]]
print(arr1_1.shape) # (1, 3)
print(arr1_1.T)
arr1_2 = arr1[:, np.newaxis]
print(arr1_2)
print(arr1_2.shape) # (3, 1)
arr1_3 = np.atleast_2d(arr1)
print(arr1_3) # [[1 2 3]]
print(arr1_3.T)

array分割

import numpy as np

arr1 = np.arange(12).reshape((3, 4))
print(arr1)
arr2, arr3 = np.split(arr1, 2, axis=1) # 水平方向分割,分成2份
print(arr2)
print(arr3)
arr4, arr5, arr6 = np.split(arr1, 3, axis=0) # 垂直方向分割,分成2份
print(arr4)
print(arr5)
print(arr6)
arr7, arr8, arr9 = np.array_split(arr1, 3, axis=1) # 水平方向分割成3份,不等分割
print(arr7)
print(arr8)
print(arr9)
arrv1, arrv2, arrv3 = np.vsplit(arr1, 3) # 垂直分割
print(arrv1)
print(arrv2)
print(arrv3)
arrh1, arrh2 = np.hsplit(arr1, 2) # 水平分割
print(arrh1)
print(arrh2)

numpy的浅拷贝和深拷贝

import numpy as np

arr1 = np.array([1, 2, 3])
arr2 = arr1 # 引用赋值,共享一块内存,浅拷贝
arr2[0] = 5
print(arr1)
print(arr2)
arr3 = arr1.copy() # 深拷贝
arr3[0] = 10
print(arr1)
print(arr3)

转载请注明博文出处。

python numpy学习的更多相关文章

  1. Python NumPy学习总结

    一.NumPy简介 其官网是:http://www.numpy.org/ NumPy是Python语言的一个扩充程序库.支持高级大量的维度数组与矩阵运算,此外也针对数组运算提供大量的数学函数库.Num ...

  2. python numpy 学习

    例子 >>> import numpy as np >>> a = np.arange(15).reshape(3, 5) >>> a array ...

  3. python numpy学习记录

    numpy是一个python和矩阵相关的库,在机器学习中非常有用,记录下numpy的基本用法 numpy的数组类叫做ndarray也叫做数组,跟python标准库中的array.array不同,后者只 ...

  4. Python numpy学习笔记(一)

    下边代码是关于numpy的一些基本用法,包括数组和矩阵操作等... import numpy as np print "<== print version ==>" p ...

  5. (转)Python数据分析之numpy学习

    原文:https://www.cnblogs.com/nxld/p/6058572.html https://morvanzhou.github.io/tutorials/data-manipulat ...

  6. Python: NumPy, Pandas学习资料

    NumPy 学习资料 书籍 NumPy Cookbook_[Idris2012] NumPy Beginner's Guide,3rd_[Idris2015] Python数据分析基础教程:NumPy ...

  7. Python数据分析:Numpy学习笔记

    Numpy学习笔记 ndarray多维数组 创建 import numpy as np np.array([1,2,3,4]) np.array([1,2,3,4,],[5,6,7,8]) np.ze ...

  8. Comprehensive learning path – Data Science in Python深入学习路径-使用python数据中学习

    http://blog.csdn.net/pipisorry/article/details/44245575 关于怎么学习python,并将python用于数据科学.数据分析.机器学习中的一篇非常好 ...

  9. Day1 Python基础学习

    一.编程语言分类 1.简介 机器语言:站在计算机的角度,说计算机能听懂的语言,那就是直接用二进制编程,直接操作硬件 汇编语言:站在计算机的角度,简写的英文标识符取代二进制去编写程序,本质仍然是直接操作 ...

随机推荐

  1. redis操作总结

    一.redis 终端操作命令: 1.redis-server.exe redis.windows.conf #指定配置文件启动 2.redis-cli #链接redis数据库 3.select 1 # ...

  2. day4-01 流程控制

    目录 一.if语法 1.什么是if? 2.语法结构 2.1.if 条件: 2.2.if...else: 2.3.if...elif...else: 2.4.if嵌套 二.循环结构 2.1 什么是循环结 ...

  3. 七牛云图片存储---Java

    一.新建存储空间 到七牛云官网注册一个账号 新建一个存储空间 到个人中心获取秘钥 二.新建Java项目 1.pom.xml配置 <dependency> <groupId>co ...

  4. Vue入坑第一篇

    写在前面的话:文章是个人学习过程中的总结,为方便以后回头在学习.文章中会参考官方文档和其他的一些文章,示例均为亲自编写和实践,若有写的不对的地方欢迎大家和我一起交流. 一.前言 本篇作为vue入门的一 ...

  5. Educational Codeforces Round 71 (Rated for Div. 2)E. XOR Guessing

    一道容斥题 如果直接做就是找到所有出现过递减的不同排列,当时硬钢到自闭,然后在凯妹毁人不倦的教导下想到可以容斥做,就是:所有的排列设为a,只考虑第一个非递减设为b,第二个非递减设为c+两个都非递减的情 ...

  6. (数据科学学习手札70)面向数据科学的Python多进程简介及应用

    本文对应脚本已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 一.简介 进程是计算机系统中资源分配的最小单位,也是操作系 ...

  7. CSPS模拟 57

    rank4大众rank T1 天空龙 让他自由翱翔吧 T2 巨神兵 对于n=10的测试点本可以打出非常优秀的分层状压 但是没有打出来,因为对拓扑图理解不够深刻,纠结于指回的边,实际上只关注伸出的边就可 ...

  8. 『题解』洛谷P2357 守墓人

    Portal Portal1: Luogu Description 在一个荒凉的墓地上有一个令人尊敬的守墓人,他看守的墓地从来没有被盗过, 所以人们很放心的把自己的先人的墓安顿在他那守墓人能看好这片墓 ...

  9. 聚类——密度聚类DBSCAN

    Clustering 聚类 密度聚类——DBSCAN 前面我们已经介绍了两种聚类算法:k-means和谱聚类.今天,我们来介绍一种基于密度的聚类算法——DBSCAN,它是最经典的密度聚类算法,是很多算 ...

  10. fpm打包神奇rpm包升级python2.7.16

    fpm打包神器参考文档:https://www.cnblogs.com/flintlovesam/p/6594635.html FPM的安装:安装ruby环境和gem命令: yum -y instal ...