Python中文社区我爱编程

numpy数组运用

2017-05-18  本文已影响29人  乾坤瞬间

# -*- coding: utf-8 -*-

"""

Created on Thu May 18 16:17:40 2017

@author: zhangll

"""

>>> import numpy as np

####################1.创建数组使用 np.array 队列创建数组###########################

#方法一 调用函数并用[]列表形式

>>> array=np.array([0,1,2,3])

#可多个列表并联

>>> array_com=np.array([[0,1,2,3],[4,5,6,7]])

#方法二 调用函数并用()元祖形式tuple

>>> array2=np.array((0,1,2,3))

#以上(可以用圆括号代替方括号)

>>> array_com=np.array([(0,1,2,3),(4,5,6,7)])

>>> array_com=np.array(((0,1,2,3),(4,5,6,7)))

>>> array_com=np.array(([0,1,2,3],[4,5,6,7]))

#以上方法的复合列表相当于是一个行向量与行向量的拼接

################################2.array属性####################################

#通过调用shape来查看,注意属性是一个类的变量,调用变量不会出现括号的

>>> array_com_attr=array_com.shape

#结果(2L, 4L),这个意思的理解我们首先要理解轴的概念,就像坐标轴x,y一样

#我们需要一种概念来解释结果(2L, 4L),这是一个元组,用array_com_attr[0]获取2L

#那么我们很自然地认为这个是0**的元素,**可以用轴概念去理解,那么我们就会很容易理解

#第0轴的长度为2,第1轴的长度为4,这样以数字轴概念来理解比利用x,y(行轴,列轴)来

#理解容易地多

#2.1 利用array的shape函数来修改原列表的长宽

>>> array_com.shape=4,2

#array_com 结果变成 Out[*]: array([[0, 1],[2, 3],[4, 5],[6, 7]])

#可以这么理解,把原先的列表按照0轴一次展开留下的列表,然后对其进行每组2个元素的

#组合分配,共分配4个元祖列表

>>> array_com.shape=3,2

#如果形状变成(4,1)(3,2)(4,3)的性状会报错,那是因为元素的总量要前后保持一致

#少了丢失数据,大了又耗内存,要刚刚好

###########################3.array元素的类型####################################

#我们如果想知道array的元素类型,只要通过输入代码set(np.typeDict.values())

#就能知道我们想要的元素类,如果想要知道某个array的元素类型只要输入如下:

>>> array_com.dtype

#Out[*]: dtype('int32') 它是一个32位的int数据类型

#因此如果想存储32位的数据,请使用如下

>>> array_com=np.array([[0,1,2,3],[4,5,6,7]],dtype=np.int32)

>>> array_com.dtype

#Out[*]: dtype('int64')

###3.1 可以通过元组的dtype修改元素类型

>>>  array_com.dtype=np.int16

#array_com 为([[0, 0, 1, 0, 2, 0, 3, 0],[4, 0, 5, 0, 6, 0, 7, 0]])

#该为64位的元素比如6这个以32位存储的字节形式为【00000000c 00000000b】 【00000000a 00000006】

#而python通过cpu以小端序(一般计算机都是利用小端序的方式读取传输数据)方式重新组合成

#两个16位的数据形式为【00000006 00000000a】 【00000000b 00000000c】,是以小端序的形式显示的

在这里再说明下小端序的理解

整数是以小端序的方式存储在内存的。即读数据的时候先高

如下fromstring函数是把字符串格式存储为指定的格式,参数如下即把“abcd”字符串存储为4个8位的值

np.fromstring("abcd",dtype=np.int8)

Out[151]: array([ 97,  98,  99, 100], dtype=int8)

参数如下即把“abcd”字符串存储为2个16位的值

np.fromstring("abcd",dtype=np.int16)

Out[152]: array([25185, 25699], dtype=int16)

98*pow(2,8)+97

Out[153]: 25185

100*pow(2,8)+99

Out[154]: 25699

在这里就比较清楚理解小端序的存储方式了

#########################4.如何通过坐标来获取元素###########################

#以array_com为例,python一般都是以0作为第一元素的坐标,这个跟java等等语言很像

#至于为什么会有这么神奇的设定?我也不太清楚。感觉这是约定俗成的

########4.1获取第一个数组[0]坐标为零

>>> array03=array_com[0,3]

#Out[*]: 3,注意的是单个获取坐标是对原数组的一个拷贝,而不是链接

########4.2获取第一一个连续坐标的切片方法,该方法是对原array的一个映像(链接)

>>> arr_cut1=array_com[0,2:3]#[2,3)不包含第3轴的数据

>>> array_com[0,2]=100

>>> arr_cut1#array([100], dtype=int64)

#切片有一些技巧,a)比如array_com[0,1:-1] 切片中的-1代表元素倒数第一元素即array_com[0,1:4]

#            b) array_com[0,1:] 相当于array_com[0,1:5]

#            c)array_com[0,1::2] 相当于array_com[0,[1,3]]

#########################5.其他数据生成形式###########################

#5.1 np.arange() 等差数列 隔距 生成方法

>>> np.arange(0,1,0.2)

#Out[*]: array([ 0. ,  0.2,  0.4,  0.6,  0.8]) 可以看出,是[0,1)每隔0.2步长的数组

#而1是不包含的与 切片中的 0:1:0.2类似

#5.2 np.linspace() 线性等差数列 固定步长 生成方法

>>> np.linspace(0,1,10)

#得到的结果array([ 0.        ,  0.11111111,  0.22222222,  0.33333333,  0.44444444,

#        0.55555556,  0.66666667,  0.77777778,  0.88888889,  1.        ])

#可以发现是一个从[0,1)包含10个元素隔距为1/9的元组列表,如果以1/10为隔距,则需要加个参数

>>> np.linspace(0,1,10,endpoint=False)

# 结果  array([ 0. ,  0.1,  0.2,  0.3,  0.4,  0.5,  0.6,  0.7,  0.8,  0.9])

#5.2.1 类似于linspace 还有 np.logspace(0,2,5)

>>> np.logspace(0,2,5)

#array([1,3.166,10,31.62,100.])

#[10^0,10^2) 以10为底的指数数列,要是想改变底数,只要添加base参数(基础)

>>> np.logspace(0,2,5,base=2)

#array([1,1.41,2,2.83,4])它也有endpoint参数同上

#5.2.2 生成一些函数zeros(),ones(),empty()类似于matlab的生成模式

#如下为创造0轴为2个长度,1轴为5个长度的

np.empty((2,5),np.int)

np.empty([2,5],np.int)

#可以用()[]互相替换

np.zeros([2,5],np.int)

np.ones([2,5],np.int)

上一篇下一篇

猜你喜欢

热点阅读