• 吴裕雄--天生自然Numpy库学习笔记:Numpy 数组操作


    import numpy as np
     
    a = np.arange(8)
    print ('原始数组:')
    print (a)
    print ('
    ')
     
    b = a.reshape(4,2)
    print ('修改后的数组:')
    print (b)
    numpy.ndarray.flat 是一个数组元素迭代器
    import numpy as np
     
    a = np.arange(9).reshape(3,3) 
    print ('原始数组:')
    for row in a:
        print (row)
     
    #对数组中每个元素都进行处理,可以使用flat属性,该属性是一个数组元素迭代器:
    print ('迭代后的数组:')
    for element in a.flat:
        print (element)

    import numpy as np
     
    a = np.arange(8).reshape(2,4)
     
    print ('原数组:')
    print (a)
    print ('
    ')
    # 默认按行
     
    print ('展开的数组:')
    print (a.flatten())
    print ('
    ')
     
    print ('以 F 风格顺序展开的数组:')
    print (a.flatten(order = 'F'))
    numpy.ravel() 展平的数组元素,顺序通常是"C风格",返回的是数组视图
    numpy.ravel(a, order='C')
    参数说明:
    order:'C' -- 按行,'F' -- 按列,'A' -- 原顺序,'K' -- 元素在内存中的出现顺序。
    import numpy as np
     
    a = np.arange(8).reshape(2,4)
     
    print ('原数组:')
    print (a)
    print ('
    ')
     
    print ('调用 ravel 函数之后:')
    print (a.ravel())
    print ('
    ')
     
    print ('以 F 风格顺序调用 ravel 函数之后:')
    print (a.ravel(order = 'F'))

    import numpy as np
     
    a = np.arange(12).reshape(3,4)
     
    print ('原数组:')
    print (a )
    print ('
    ')
     
    print ('对换数组:')
    print (np.transpose(a))
    import numpy as np
     
    a = np.arange(12).reshape(3,4)
     
    print ('原数组:')
    print (a)
    print ('
    ')
     
    print ('转置数组:')
    print (a.T)

    import numpy as np
     
    # 创建了三维的 ndarray
    a = np.arange(8).reshape(2,2,2)
     
    print ('原数组:')
    print (a)
    print ('
    ')
    # 将轴 2 滚动到轴 0(宽度到深度)
     
    print ('调用 rollaxis 函数:')
    print (np.rollaxis(a,2))
    # 将轴 0 滚动到轴 1:(宽度到高度)
    print ('
    ')
     
    print ('调用 rollaxis 函数:')
    print (np.rollaxis(a,2,1))

    import numpy as np
     
    # 创建了三维的 ndarray
    a = np.arange(8).reshape(2,2,2)
     
    print ('原数组:')
    print (a)
    print ('
    ')
    # 现在交换轴 0(深度方向)到轴 2(宽度方向)
     
    print ('调用 swapaxes 函数后的数组:')
    print (np.swapaxes(a, 2, 0))
    numpy.broadcast 用于模仿广播的对象,它返回一个对象,该对象封装了将一个数组广播到另一个数组的结果。
    该函数使用两个数组作为输入参数
    import numpy as np
     
    x = np.array([[1], [2], [3]])
    y = np.array([4, 5, 6])  
     
    # 对 y 广播 x
    b = np.broadcast(x,y)  
    # 它拥有 iterator 属性,基于自身组件的迭代器元组
     
    print ('对 y 广播 x:')
    r,c = b.iters
     
    # Python3.x 为 next(context) ,Python2.x 为 context.next()
    print (next(r), next(c))
    print (next(r), next(c))
    print ('
    ')
    # shape 属性返回广播对象的形状
     
    print ('广播对象的形状:')
    print (b.shape)
    print ('
    ')
    # 手动使用 broadcast 将 x 与 y 相加
    b = np.broadcast(x,y)
    c = np.empty(b.shape)
     
    print ('手动使用 broadcast 将 x 与 y 相加:')
    print (c.shape)
    print ('
    ')
    c.flat = [u + v for (u,v) in b]
     
    print ('调用 flat 函数:')
    print (c)
    print ('
    ')
    # 获得了和 NumPy 内建的广播支持相同的结果
     
    print ('x 与 y 的和:')
    print (x + y)
    numpy.broadcast_to 函数将数组广播到新形状。它在原始数组上返回只读视图。 它通常不连续。 如果新形状不符合 NumPy 的广播规则,该函数可能会抛出ValueError。
    import numpy as np
     
    a = np.arange(4).reshape(1,4)
     
    print ('原数组:')
    print (a)
    print ('
    ')
     
    print ('调用 broadcast_to 函数之后:')
    print (np.broadcast_to(a,(4,4)))

    import numpy as np
     
    x = np.array(([1,2],[3,4]))
     
    print ('数组 x:')
    print (x)
    print ('
    ')
    y = np.expand_dims(x, axis = 0)
     
    print ('数组 y:')
    print (y)
    print ('
    ')
     
    print ('数组 x 和 y 的形状:')
    print (x.shape, y.shape)
    print ('
    ')
    # 在位置 1 插入轴
    y = np.expand_dims(x, axis = 1)
     
    print ('在位置 1 插入轴之后的数组 y:')
    print (y)
    print ('
    ')
     
    print ('x.ndim 和 y.ndim:')
    print (x.ndim,y.ndim)
    print ('
    ')
     
    print ('x.shape 和 y.shape:')
    print (x.shape, y.shape)

    import numpy as np
     
    x = np.arange(9).reshape(1,3,3)
     
    print ('数组 x:')
    print (x)
    print ('
    ')
    y = np.squeeze(x)
     
    print ('数组 y:')
    print (y)
    print ('
    ')
     
    print ('数组 x 和 y 的形状:')
    print (x.shape, y.shape)

    import numpy as np
     
    a = np.array([[1,2],[3,4]])
     
    print ('第一个数组:')
    print (a)
    print ('
    ')
    b = np.array([[5,6],[7,8]])
     
    print ('第二个数组:')
    print (b)
    print ('
    ')
    # 两个数组的维度相同
     
    print ('沿轴 0 连接两个数组:')
    print (np.concatenate((a,b)))
    print ('
    ')
     
    print ('沿轴 1 连接两个数组:')
    print (np.concatenate((a,b),axis = 1))

    import numpy as np
     
    a = np.array([[1,2],[3,4]])
     
    print ('第一个数组:')
    print (a)
    print ('
    ')
    b = np.array([[5,6],[7,8]])
     
    print ('第二个数组:')
    print (b)
    print ('
    ')
     
    print ('沿轴 0 堆叠两个数组:')
    print (np.stack((a,b),0))
    print ('
    ')
     
    print ('沿轴 1 堆叠两个数组:')
    print (np.stack((a,b),1))
    numpy.hstack 是 numpy.stack 函数的变体,它通过水平堆叠来生成数组。
    import numpy as np
     
    a = np.array([[1,2],[3,4]])
     
    print ('第一个数组:')
    print (a)
    print ('
    ')
    b = np.array([[5,6],[7,8]])
     
    print ('第二个数组:')
    print (b)
    print ('
    ')
     
    print ('水平堆叠:')
    c = np.hstack((a,b))
    print (c)
    print ('
    ')
    numpy.vstack 是 numpy.stack 函数的变体,它通过垂直堆叠来生成数组。
    import numpy as np
     
    a = np.array([[1,2],[3,4]])
     
    print ('第一个数组:')
    print (a)
    print ('
    ')
    b = np.array([[5,6],[7,8]])
     
    print ('第二个数组:')
    print (b)
    print ('
    ')
     
    print ('竖直堆叠:')
    c = np.vstack((a,b))
    print (c)

    import numpy as np
     
    a = np.arange(9)
     
    print ('第一个数组:')
    print (a)
    print ('
    ')
     
    print ('将数组分为三个大小相等的子数组:')
    b = np.split(a,3)
    print (b)
    print ('
    ')
     
    print ('将数组在一维数组中表明的位置分割:')
    b = np.split(a,[4,7])
    print (b)
    numpy.hsplit 函数用于水平分割数组,通过指定要返回的相同形状的数组数量来拆分原数组。
    import numpy as np
     
    harr = np.floor(10 * np.random.random((2, 6)))
    print ('原array:')
    print(harr)
     
    print ('拆分后:')
    print(np.hsplit(harr, 3))
    numpy.vsplit 沿着垂直轴分割,其分割方式与hsplit用法相同。
    import numpy as np
     
    a = np.arange(16).reshape(4,4)
     
    print ('第一个数组:')
    print (a)
    print ('
    ')
     
    print ('竖直分割:')
    b = np.vsplit(a,2)
    print (b)

    import numpy as np
     
    a = np.array([[1,2,3],[4,5,6]])
     
    print ('第一个数组:')
    print (a)
    print ('
    ')
     
    print ('第一个数组的形状:')
    print (a.shape)
    print ('
    ')
    b = np.resize(a, (3,2))
     
    print ('第二个数组:')
    print (b)
    print ('
    ')
     
    print ('第二个数组的形状:')
    print (b.shape)
    print ('
    ')
    # 要注意 a 的第一行在 b 中重复出现,因为尺寸变大了
     
    print ('修改第二个数组的大小:')
    b = np.resize(a,(3,3))
    print (b)
    numpy.append 函数在数组的末尾添加值。 追加操作会分配整个数组,并把原来的数组复制到新数组中。 此外,输入数组的维度必须匹配否则将生成ValueError。
    append 函数返回的始终是一个一维数组。
    numpy.append(arr, values, axis=None)
    参数说明:
    arr:输入数组
    values:要向arr添加的值,需要和arr形状相同(除了要添加的轴)
    axis:默认为 None。当axis无定义时,是横向加成,返回总是为一维数组!当axis有定义的时候,分别为0和1的时候。当axis有定义的时候,分别为0和1的时候(列数要相同)。当axis为1时,数组是加在右边(行数要相同)。
    import numpy as np
     
    a = np.array([[1,2,3],[4,5,6]])
     
    print ('第一个数组:')
    print (a)
    print ('
    ')
     
    print ('向数组添加元素:')
    print (np.append(a, [7,8,9]))
    print ('
    ')
     
    print ('沿轴 0 添加元素:')
    print (np.append(a, [[7,8,9]],axis = 0))
    print ('
    ')
     
    print ('沿轴 1 添加元素:')
    print (np.append(a, [[5,5,5],[7,8,9]],axis = 1))
    numpy.insert 函数在给定索引之前,沿给定轴在输入数组中插入值。
    如果值的类型转换为要插入,则它与输入数组不同。 插入没有原地的,函数会返回一个新数组。 此外,如果未提供轴,则输入数组会被展开。
    numpy.insert(arr, obj, values, axis)
    参数说明:
    arr:输入数组
    obj:在其之前插入值的索引
    values:要插入的值
    axis:沿着它插入的轴,如果未提供,则输入数组会被展开
    import numpy as np
     
    a = np.array([[1,2],[3,4],[5,6]])
     
    print ('第一个数组:')
    print (a)
    print ('
    ')
     
    print ('未传递 Axis 参数。 在插入之前输入数组会被展开。')
    print (np.insert(a,3,[11,12]))
    print ('
    ')
    print ('传递了 Axis 参数。 会广播值数组来配输入数组。')
     
    print ('沿轴 0 广播:')
    print (np.insert(a,1,[11],axis = 0))
    print ('
    ')
     
    print ('沿轴 1 广播:')
    print (np.insert(a,1,11,axis = 1))

    import numpy as np
     
    a = np.arange(12).reshape(3,4)
     
    print ('第一个数组:')
    print (a)
    print ('
    ')
     
    print ('未传递 Axis 参数。 在插入之前输入数组会被展开。')
    print (np.delete(a,5))
    print ('
    ')
     
    print ('删除第二列:')
    print (np.delete(a,1,axis = 1))
    print ('
    ')
     
    print ('包含从数组中删除的替代值的切片:')
    a = np.array([1,2,3,4,5,6,7,8,9,10])
    print (np.delete(a, np.s_[::2]))

    import numpy as np
     
    a = np.array([5,2,6,2,7,5,6,8,2,9])
     
    print ('第一个数组:')
    print (a)
    print ('
    ')
     
    print ('第一个数组的去重值:')
    u = np.unique(a)
    print (u)
    print ('
    ')
     
    print ('去重数组的索引数组:')
    u,indices = np.unique(a, return_index = True)
    print (indices)
    print ('
    ')
     
    print ('我们可以看到每个和原数组下标对应的数值:')
    print (a)
    print ('
    ')
     
    print ('去重数组的下标:')
    u,indices = np.unique(a,return_inverse = True)
    print (u)
    print ('
    ')
     
    print ('下标为:')
    print (indices)
    print ('
    ')
     
    print ('使用下标重构原数组:')
    print (u[indices])
    print ('
    ')
     
    print ('返回去重元素的重复数量:')
    u,indices = np.unique(a,return_counts = True)
    print (u)
    print (indices)
  • 相关阅读:
    Redis键是如何过期删除的
    使用EventBus + Redis发布订阅模式提升业务执行性能(下)
    使用EventBus + Redis发布订阅模式提升业务执行性能
    使用C#的计时器加观察者模式完成报警推送需求
    Go 语言入门教程:变量
    Go 语言入门教程:安装
    Docker 入门:Dockerfile
    Docker 入门:容器
    Docker 入门:什么是 Docker ?
    Windows 系统如何安装 Docker
  • 原文地址:https://www.cnblogs.com/tszr/p/12228868.html
Copyright © 2020-2023  润新知