经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » NumPy » 查看文章
numpy和pandas中数组的合并、拉直和重塑实例
来源:jb51  时间:2019/6/28 10:18:19  对本文有异议

合并

在numpy中合并两个array

numpy中可以通过concatenate,参数axis=0表示在垂直方向上合并两个数组,等价于np.vstack;参数axis=1表示在水平方向上合并两个数组,等价于np.hstack。

垂直方向:

  1. np.concatenate([arr1,arr2],axis=0)
  2. np.vstack([arr1,arr2])

水平方向:

  1. np.concatenate([arr1,arr2],axis=1)
  2. np.hstack([arr1,arr2])
  1. import numpy as np
  2. import pandas as pd
  3.  
  4. arr1=np.ones((3,5))
  5. arr1
  6. Out[5]:
  7. array([[ 1., 1., 1., 1., 1.],
  8. [ 1., 1., 1., 1., 1.],
  9. [ 1., 1., 1., 1., 1.]])
  10. arr2=np.random.randn(15).reshape(arr1.shape)
  11. arr2
  12. Out[8]:
  13. array([[-0.09666833, 1.47064828, -1.94608976, 0.2651279 , -0.32894787],
  14. [ 1.01187699, 0.39171167, 1.49607091, 0.79216196, 0.33246644],
  15. [ 1.71266238, 0.86650837, 0.77830394, -0.90519422, 1.55410056]])
  16. np.concatenate([arr1,arr2],axis=0) #在纵轴上合并
  17. Out[9]:
  18. array([[ 1. , 1. , 1. , 1. , 1. ],
  19. [ 1. , 1. , 1. , 1. , 1. ],
  20. [ 1. , 1. , 1. , 1. , 1. ],
  21. [-0.09666833, 1.47064828, -1.94608976, 0.2651279 , -0.32894787],
  22. [ 1.01187699, 0.39171167, 1.49607091, 0.79216196, 0.33246644],
  23. [ 1.71266238, 0.86650837, 0.77830394, -0.90519422, 1.55410056]])
  24.  
  25. np.concatenate([arr1,arr2],axis=1) #在横轴上合并
  26. Out[10]:
  27. array([[ 1. , 1. , 1. , ..., -1.94608976,
  28. 0.2651279 , -0.32894787],
  29. [ 1. , 1. , 1. , ..., 1.49607091,
  30. 0.79216196, 0.33246644],
  31. [ 1. , 1. , 1. , ..., 0.77830394,
  32. -0.90519422, 1.55410056]])

在pandas中合并两个DataFrame

pandas中通过concat方法实现合并,指定参数axis=0 或者 axis=1,在纵轴和横轴上合并两个数组。与numpy不同,这里的两个dataframe要放在一个列表中,即[frame1,frame2]

  1. from pandas import DataFrame
  2.  
  3. frame1=DataFrame([[1,2,3],[4,5,6]])
  4. frame2=DataFrame([[7,8,9],[10,11,12]])
  5.  
  6. pd.concat([frame1,frame2], ignore_index=True) # 合并的数组是一个可迭代的列表。
  7. Out[25]:
  8. 0 1 2
  9. 0 1 2 3
  10. 1 4 5 6
  11. 0 7 8 9
  12. 1 10 11 12
  13.  
  14.  
  15. pd.concat([frame1,frame2], axis=1, ignore_index=True)
  16. Out[27]:
  17. 0 1 2 3 4 5
  18. 0 1 2 3 7 8 9
  19. 1 4 5 6 10 11 12

拉直和重塑

拉直即把一个二维的array变成一个一维的array。默认情况下,Numpy数组是按行优先顺序创建。在空间方面,这就意味着,对于一个二维数字,每行中的数据项是存放在内在中相邻的位置上的。另一种顺序是列优先。

由于历史原因,行优先和列优先又分别被称为C和Fortran顺序。在Numpy中,可以通过关键字参数order=‘C' 和order=‘F' 来实现行优先和列优先。

拉直:

  1. arr=np.arange(15).reshape(3,-1)
  2. arr
  3. Out[29]:
  4. array([[ 0, 1, 2, 3, 4],
  5. [ 5, 6, 7, 8, 9],
  6. [10, 11, 12, 13, 14]])
  7. arr.ravel('F') #按照列优先,扁平化。
  8. Out[30]: array([ 0, 5, 10, ..., 4, 9, 14])
  9.  
  10. arr.ravel('C') # 默认顺序。#按照行优先,扁平化。
  11. Out[31]: array([ 0, 1, 2, ..., 12, 13, 14])

重塑:

Fortran顺序重塑后按列拉直和原数据按列拉直一样。

  1. arr.reshape((5,3),order='F')
  2. Out[32]:
  3. array([[ 0, 11, 8],
  4. [ 5, 2, 13],
  5. [10, 7, 4],
  6. [ 1, 12, 9],
  7. [ 6, 3, 14]])

C顺序重塑后按行拉直和原数据按行拉直一样。

  1. arr.reshape((5,3),order='C')
  2. Out[33]:
  3. array([[ 0, 1, 2],
  4. [ 3, 4, 5],
  5. [ 6, 7, 8],
  6. [ 9, 10, 11],
  7. [12, 13, 14]])

以上这篇numpy和pandas中数组的合并、拉直和重塑实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号