感觉numpy.hstack()和numpy.column_stack()函数略有相似,numpy.vstack()与numpy.row_stack()函数也是挺像的。

stackoverflow上也有类似的讨论,在这里numpy vstack vs. column_stack

给一个相关函数的列表:

stack()    Join a sequence of arrays along a new axis.

hstack()    Stack arrays in sequence horizontally (column wise).

dstack()    Stack arrays in sequence depth wise (along third dimension).

concatenate()     Join a sequence of arrays along an existing axis.

vsplit ()   Split array into a list of multiple sub-arrays vertically.

一、numpy.stack()函数

函数原型:numpy.stack(arrays, axis=0)

程序实例:

  1. >>> arrays = [np.random.randn(3, 4) for _ in range(10)]
  2. >>> np.stack(arrays, axis=0).shape
  3. (10, 3, 4)
  4. >>>
  5. >>> np.stack(arrays, axis=1).shape
  6. (3, 10, 4)
  7. >>>
  8. >>> np.stack(arrays, axis=2).shape
  9. (3, 4, 10)
  10. >>>
  11. >>> a = np.array([1, 2, 3])
  12. >>> b = np.array([2, 3, 4])
  13. >>> np.stack((a, b))
  14. array([[1, 2, 3],
  15. [2, 3, 4]])
  16. >>>
  17. >>> np.stack((a, b), axis=-1)
  18. array([[1, 2],
  19. [2, 3],
  20. [3, 4]])

二、numpy.hstack()函数

函数原型:numpy.hstack(tup)

其中tup是arrays序列,The arrays must have the same shape, except in the dimensioncorresponding to
axis (the first, by default).

等价于:np.concatenate(tup, axis=1)

程序实例:

  1. >>> a = np.array((1,2,3))
  2. >>> b = np.array((2,3,4))
  3. >>> np.hstack((a,b))
  4. array([1, 2, 3, 2, 3, 4])
  5. >>> a = np.array([[1],[2],[3]])
  6. >>> b = np.array([[2],[3],[4]])
  7. >>> np.hstack((a,b))
  8. array([[1, 2],
  9. [2, 3],
  10. [3, 4]])

三、numpy.vstack()函数

函数原型:numpy.vstack(tup)

等价于:np.concatenate(tup, axis=0) if tup contains arrays thatare at least 2-dimensional.

程序实例:

  1. >>> a = np.array([1, 2, 3])
  2. >>> b = np.array([2, 3, 4])
  3. >>> np.vstack((a,b))
  4. array([[1, 2, 3],
  5. [2, 3, 4]])
  6. >>>
  7. >>> a = np.array([[1], [2], [3]])
  8. >>> b = np.array([[2], [3], [4]])
  9. >>> np.vstack((a,b))
  10. array([[1],
  11. [2],
  12. [3],
  13. [2],
  14. [3],
  15. [4]])

四、numpy.dstack()函数

函数原型:numpy.dstack(tup)

等价于:np.concatenate(tup, axis=2)

程序实例:

  1. >>> a = np.array((1,2,3))
  2. >>> b = np.array((2,3,4))
  3. >>> np.dstack((a,b))
  4. array([[[1, 2],
  5. [2, 3],
  6. [3, 4]]])
  7. >>>
  8. >>> a = np.array([[1],[2],[3]])
  9. >>> b = np.array([[2],[3],[4]])
  10. >>> np.dstack((a,b))
  11. array([[[1, 2]],
  12. [[2, 3]],
  13. [[3, 4]]])

五、numpy.concatenate()函数

函数原型:numpy.concatenate((a1, a2, ...), axis=0)

程序实例:

  1. >>> a = np.array([[1, 2], [3, 4]])
  2. >>> b = np.array([[5, 6]])
  3. >>> np.concatenate((a, b), axis=0)
  4. array([[1, 2],
  5. [3, 4],
  6. [5, 6]])
  7. >>> np.concatenate((a, b.T), axis=1)
  8. array([[1, 2, 5],
  9. [3, 4, 6]])
  10. This function will not preserve masking of MaskedArray inputs.
  11. >>>
  12. >>> a = np.ma.arange(3)
  13. >>> a[1] = np.ma.masked
  14. >>> b = np.arange(2, 5)
  15. >>> a
  16. masked_array(data = [0 -- 2],
  17. mask = [False  True False],
  18. fill_value = 999999)
  19. >>> b
  20. array([2, 3, 4])
  21. >>> np.concatenate([a, b])
  22. masked_array(data = [0 1 2 2 3 4],
  23. mask = False,
  24. fill_value = 999999)
  25. >>> np.ma.concatenate([a, b])
  26. masked_array(data = [0 -- 2 2 3 4],
  27. mask = [False  True False False False False],
  28. fill_value = 999999)

六、numpy.vsplit()函数

函数原型:numpy.vsplit(ary, indices_or_sections)

程序实例:

  1. >>> x = np.arange(16.0).reshape(4, 4)
  2. >>> x
  3. array([[  0.,   1.,   2.,   3.],
  4. [  4.,   5.,   6.,   7.],
  5. [  8.,   9.,  10.,  11.],
  6. [ 12.,  13.,  14.,  15.]])
  7. >>> np.vsplit(x, 2)
  8. [array([[ 0.,  1.,  2.,  3.],
  9. [ 4.,  5.,  6.,  7.]]),
  10. array([[  8.,   9.,  10.,  11.],
  11. [ 12.,  13.,  14.,  15.]])]
  12. >>> np.vsplit(x, np.array([3, 6]))
  13. [array([[  0.,   1.,   2.,   3.],
  14. [  4.,   5.,   6.,   7.],
  15. [  8.,   9.,  10.,  11.]]),
  16. array([[ 12.,  13.,  14.,  15.]]),
  17. array([], dtype=float64)]
  18. With a higher dimensional array the split is still along the first axis.
  19. >>>
  20. >>> x = np.arange(8.0).reshape(2, 2, 2)
  21. >>> x
  22. array([[[ 0.,  1.],
  23. [ 2.,  3.]],
  24. [[ 4.,  5.],
  25. [ 6.,  7.]]])
  26. >>> np.vsplit(x, 2)
  27. [array([[[ 0.,  1.],
  28. [ 2.,  3.]]]),
  29. array([[[ 4.,  5.],
  30. [ 6.,  7.]]])]

参考:

numpy中的部分源码

Python numpy函数hstack() vstack() stack() dstack() vsplit() concatenate()的更多相关文章

  1. [转]Python numpy函数hstack() vstack() stack() dstack() vsplit() concatenate()

    Python numpy函数hstack() vstack() stack() dstack() vsplit() concatenate() 觉得有用的话,欢迎一起讨论相互学习~Follow Me ...

  2. numpy函数hstack,vstack,dstack简介

    vstack.hstack和dstack都用于把几个小数组合并成一个大数组.它们的差别是小数组的元素在大数组中的排列顺序有所不同.把两部手机摆到一起有几种方式?水平的左右排列,垂直的上下排列,还可以把 ...

  3. Python numpy函数:reshape()

    reshape()函数用于改变数组对象的形状: import numpy as np a = np.array([1,2,3,4,5,6,7,8]) #转换成2D数组 b = a.reshape((2 ...

  4. Python numpy函数:transpose()

    transpose用于对高维数组进行转置,转置时候需要一个由轴编号组成的元组. 比如说三维的数组,那就对维度进行编号,也就是0,1,2:这样说可能比较抽象.这里的0,1,2可以理解为对shape返回元 ...

  5. numpy函数查询手册

    写了个程序,对Numpy的绝大部分函数及其说明进行了中文翻译. 原网址:https://docs.scipy.org/doc/numpy/reference/routines.html#routine ...

  6. Python NumPy学习总结

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

  7. Python numpy中矩阵的用法总结

    关于Python Numpy库基础知识请参考博文:https://www.cnblogs.com/wj-1314/p/9722794.html Python矩阵的基本用法 mat()函数将目标数据的类 ...

  8. CS231n课程笔记翻译1:Python Numpy教程

    译者注:本文智能单元首发,翻译自斯坦福CS231n课程笔记Python Numpy Tutorial,由课程教师Andrej Karpathy授权进行翻译.本篇教程由杜客翻译完成,Flood Sung ...

  9. python的函数

    函数一词起源于数学,但是在编程中的函数和数学中的有很大不同.编程中的函数式组织好的,可重复使用的,用于实现单一功能或相关联功能的代码块. 我们在学习过程中已经使用过一些python内建的函数,如pri ...

随机推荐

  1. stm32cube--IWDG使用

    IWDG使用的是32芯片内部的40k独立晶振,该晶振为rtc和iwdg提供时钟,即使是主时钟坏了也不影响它们. 主要用到三个寄存器, IWDG_KR    键值寄存器 IWDG_PR     预分频寄 ...

  2. git reset soft,hard,mixed之区别深解

    GIT reset命令,似乎让人很迷惑,以至于误解,误用.但是事实上不应该如此难以理解,只要你理解到这个命令究竟在干什么. 首先我们来看几个术语 HEAD 这是当前分支版本顶端的别名,也就是在当前分支 ...

  3. 鼠标滚轮控制侧边div上下翻动效果

    css部分: <style> * { margin: 0; padding: 0;} .wrap { width: 1000px; margin: 0 auto; overflow: hi ...

  4. 0518Scrum项目5.0

    1.团队成员完成自己认领的任务. 2.燃尽图:理解.设计并画出本次Sprint的燃尽图的理想线.参考图6. 3.每日立会更新任务板上任务完成情况.燃尽图的实际线,分析项目进度是否在正轨.    每天的 ...

  5. 非常简单的XML解析(SAX解析、pull解析)

    这里只是把解析的数据当日志打出来了 非常简单的xml解析方式 package com.example.demo.service; import java.io.IOException; import ...

  6. CentOS修改默认编码为UTF-8,使java程序字符集默认为UTF-8

    java程序在本地接受php的utf8字符串好好的,到了服务器就行了. 解决,修改vi /etc/sysconfig/i18n,修改之后ssh断开,重连后KILL你的java. LANG=" ...

  7. Java MVC Controller 中通过不同方式获取 @PathVariable 参数值

    1.最常用,也是最直接使用方法,通过@PathVariable注解获取 @RequestMapping(value = "/test/{a}") public @ResponseB ...

  8. realestate.cei.gov.cn

    using AnfleCrawler.Common; using System; using System.Collections.Concurrent; using System.Collectio ...

  9. url编码 中文在url参数中传递,在请求头,响应头中传递,是如何编码的呢?

    一定要编码成url的吗?还是url自动把接受的汉字编码,请求头响应头到达之后再自动编码成汉字?这样似乎比较合理哦 先把iso8859-1 转换成 utf-8,在mvc中处理,然后响应的时候在转成iso ...

  10. 如何利用Cloudera Manager来手动安装parcel包

    1.问题的描述: 当你利用Cloudera Manager部署了CDH的集群后,也许随着你的业务需求,你需要对你的就去哪做一些优化,或者扩展之类的,这个时候你可能需要下载安装一些组件.例如,我最近在阅 ...