用python自带的list去处理数组效率很低, numpy就诞生了, 它提供了ndarry对象,N-dimensional object, 是存储单一数据类型的多维数组,即所有的元素都是同一种类型。索引是一个正整数元组。

秩,rank==轴, axes ==维度, dimensions ==ndim==len(shap)

一, 简单介绍:

>>> from numpy import *
>>> a = arange(10).reshape(2,5)
>>> a
array([[0, 1, 2, 3, 4],
       [5, 6, 7, 8, 9]])

arange 和自带的range形式一样,只不过返回的是一个数组对象

方法有:

dtype, 描述数组元素类型的对象, 方法有name

itemssize, 数组中每个元素的字节大小。float64的itemsize为64/8=8

ndim查看数组的秩,也称为轴, 维度。

size, 查看数组一共多少个元素。等于shap元组中的元素成绩。

shape, 数组的维度,是一个指示数组在每个维度上大小的整数元组。一个n排m列矩阵, shape为(2,3),这个元组的长度就是秩,即维度或者ndim属性。

reshape, 重新定义数组形态。

>>> type(a)
<type 'numpy.ndarray'>
>>> a.shape
(2, 5)
>>> a.ndim
2
>>> a.dtype
dtype('int64')
>>> a.dtype.name
'int64'
>>> a.itemsize
8
>>> a.size
10

二, 从列表创建数组

>>> import numpy as np
>>> a = np.array([2,3,4])   
>>> a
array([2, 3, 4])

>>> a.dtype
dtype('int64')

数组的类型由原数据的类型推倒出来。

>>> a = np.array([1.2, 3, 4, 9]) 
>>> a
array([ 1.2,  3. ,  4. ,  9. ])

>>> a.dtype
dtype('float64')

注意: np.array()接受的是一个列表,即np.array([1,2,3,4]), 而不是np.array(1,2,3,4)

序列包含序列将转化为2维数组,序列包含序列包含序列将转化为三维数组

>>> a = array([[1,2,3], [4,5,6]])   #列表中有两个元组,转化时自动转为2维数组。也可以是a = array([[1,2,3], [4,5,6]])
>>> a
array([[1, 2, 3],
       [4, 5, 6]])
>>> a.dtype
dtype('int64')
>>> a.size
6
>>> a.shape
(2, 3)

>>> a.ndim
2

在创建的时候数组类型可以指定如 a = array([[1,2,3], [4,5,6]], dtype=int32)

三, 用numpy自带方法创建全是零的数组或全是一的数组。

为什么这样做? 因为数组的元素刚开始是未知的,但是数组的大小往往是已知的,提前建好框架,节省了运算。

zeros()创建元素全是零的数组

>>> np.zeros((3,4))    #创建一个全是零的2维数组, 注意不能zeros(3,4).  类型默认均为float64. 也可以在创建的时候指定
array([[ 0.,  0.,  0.,  0.],
       [ 0.,  0.,  0.,  0.],
       [ 0.,  0.,  0.,  0.]])

>>> a = np.zeros((1,10))  
>>> a
array([[ 0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.]]) 
>>> a.dtype
dtype('float64')
>>> a.size
10
>>> a.shape   
(1, 10)
>>> a.ndim   
2

>>> b = np.zeros((10))

>>>b
array([ 0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.])

>>> b.dtype
dtype('float64')
>>> b.size
10
>>> b.shape
(10,)
>>> b.ndim
1

创建全是1的数组

>>> a = np.ones((2,3,4), dtype=np.int64)   #三维数组, 两个三行四列。

>>> a

array([[[1, 1, 1, 1],         [1, 1, 1, 1],         [1, 1, 1, 1]],

[[1, 1, 1, 1],         [1, 1, 1, 1],         [1, 1, 1, 1]]])

>>> a.shape
(2, 3, 4)

>>> a.ndim
3

四, 创建序列

>>> a = np.arange(1,10,5)   # 和range的方法差不多。起始,终止, 步进。

>>> a
array([1, 6])

>>> a.shape   
(2,)
>>> a.size
2
>>> a.ndim
1

>>> a = np.arange(0, 10, 2.5)   #步进是小数的话,返回类型为float64
>>> a
array([ 0. ,  2.5,  5. ,  7.5])
>>> a.dtype
dtype('float64')

>>> a
array([ 0. ,  2.5,  5. ,  7.5])

>>> a.reshape(1,4)
array([[ 0. ,  2.5,  5. ,  7.5]])  #转化为2维

>>> a.shape       
(4,)

>>> a.reshape(1,4).shape
(1, 4)

五, 用linspace(起始, 终止, 数列个数,是否包括终止值)创建一个等差数列数组

默认是包括终止值的。

>>> from numpy import *

>>> linspace(1, 10, 10)
array([  1.,   2.,   3.,   4.,   5.,   6.,   7.,   8.,   9.,  10.])

>>> linspace(1, 10, 10, endpoint=False)                 #默认endpoint=True
array([ 1. ,  1.9,  2.8,  3.7,  4.6,  5.5,  6.4,  7.3,  8.2,  9.1])

可以看到返回的数组dtype是浮点型:

>>> linspace(1,2,10).dtype
dtype('float64')

这个函数对用matplotlib作图的时候比较好用, 比如确定横纵坐标之类的。

六, 数组打印

一维数组打印成行, 二维数组打印成矩阵。 三维数组打印成矩阵列表。

自己尝试:

from numpy import *

>>> a = arange(24)

>>>print a

>>> print a.reshape(2,12)

>>> print a.reshape(2,3,4)

如果数组太大的话,numpy会自动省略中间部分

by freemao

FAFU

free_mao@qq.com

python numpy 模块简单介绍的更多相关文章

  1. python shutil模块简单介绍

    python shutil模块简单介绍 简介 shutil模块提供了大量的文件的高级操作.特别针对文件拷贝和删除,主要功能为目录和文件操作以及压缩操作. shutil 模块方法: copy(src, ...

  2. python paramiko 模块简单介绍

    背景,公司的很多服务包括数据库访问都需要通过跳板机访问,为日常工作及使用带来了麻烦,特别数python直接操作数据更是麻烦了,所以一直想实现python 通过跳板机访问数据库的操作. 首先了解到了 p ...

  3. python之pandas简单介绍及使用(一)

    python之pandas简单介绍及使用(一) 一. Pandas简介1.Python Data Analysis Library 或 pandas 是基于NumPy 的一种工具,该工具是为了解决数据 ...

  4. Python -- Scrapy 框架简单介绍(Scrapy 安装及项目创建)

    Python -- Scrapy 框架简单介绍 最近在学习python 爬虫,先后了解学习urllib.urllib2.requests等,后来发现爬虫也有很多框架,而推荐学习最多就是Scrapy框架 ...

  5. Python+selenium之简单介绍unittest单元测试框架

    Python+selenium之简单介绍unittest单元测试框架 一.unittest简单介绍 unittest支持测试自动化,共享测试用例中的初始化和关闭退出代码,在unittest中最小单元是 ...

  6. python+selenium之简单介绍继承

    python+selenium之简单介绍继承 一.此例简单的介绍一下继承 1.面向对象的编程带来的主要好处之一是代码的重用,实现这种重用的方法之一是通过继承机制.继承完全可以理解成类之间的类型和子类型 ...

  7. 【Python】operator 模块简单介绍

    简单介绍几个常用的函数,其他的请参考文档. operator.concat(a, b) **operator.__concat__(a, b)** 对于 a.b序列,返回 a + b(列表合并) -- ...

  8. python numpy模块

    目录 numpy模块 一维数组 二维数组(用的最多的) 获取多维数组的行和列 多维数组的索引 高级功能 多维数组的元素的替换 通过函数方法创建多维数组 矩阵的运算 点乘和转置(了解) 点乘必须 m*n ...

  9. Python学习--Selenium模块简单介绍(1)

    简介及运行流程 Selenium 是一个用于Web应用程序测试的工具.Selenium测试直接运行在浏览器中,就像真正的用户在操作一样.支持的浏览器包括IE(7, 8, 9, 10, 11),Mozi ...

随机推荐

  1. Apache启用性能优化——启用Gzip,JS压缩

    #Add deflate module for enable GZIP function LoadModule deflate_module     modules/mod_deflate.so #A ...

  2. LA 4123 - Glenbow Museum

    https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  3. Java中断言的使用(转)

    相信学过c,c++的朋友一定不会对断言感到陌生.下面介绍一下断言在JAVA中的使用,JAVA是从JDK1.4才开始支持断言的(添加了关键字assert),请注意老版的JRE不支持. 断言概述 编写代码 ...

  4. MM 不哭 (tyvj 1097)

    题目大意: 一条数轴上有 n 个 MM 在哭,需要tcboy去安慰,tcboy 一开始站在第k个MM身边,每个MM 哭都会减掉tcboy的RP. 确定安慰MM的顺序使得RP扣得最少.求 min(Rp_ ...

  5. C++-标准输入输出

    1,cout 1) 用来向标准输出打印. 2) 如果参数是char*类型,则直接输出字符串.如果想要输出地址,则需要强制转换: <<static_cast<void*>(con ...

  6. Xcode6中segue取消原push与modal(deprecated)

    xcode6 之后push 和modal 就被废弃了.只能用于ios8之前.在拖线的时候我们就可以看见. 这两个方法被废弃了,我们需要找到合适的方法来代替,这时候我们发现 show 和Present ...

  7. JAVA之关于super的用法

    JAVA之关于super的用法   路漫漫其修远兮,吾将上下而求索.——屈原<离骚> 昨天写this用法总结的时候,突然产生了一个问题,请教别人之后,有了自己的一点认识.还是把它写下来,为 ...

  8. 在shell脚本中进行条件控制以及使用循环

    转载请标明:http://www.cnblogs.com/winifred-tang94/ if条件语句语法: if [ 条件表达式 ] then 代码 else 代码 fi 注意:在上面的if条件语 ...

  9. C# 对MongoDB 进行增删改查的简单操作 (转)

    运用到的MongoDB支持的C#驱动,当前版本为1.6.0 下载地址:https://github.com/mongodb/mongo-csharp-driver/downloads 1,连接数据库 ...

  10. 添加Sql作业,新建步骤出现:从IClassFactory为CLSID为{AA40D1D6-CAEF-4A56-B9BB-D0D3DC976BA2}的COM组件创建实例失败,原因是出现以下错误:c001f011。的解决方法

    32位操作系统: 打开运行(命令提示符), 一.输入 cd c:\windows\system32 进入到c:\windows\system32路径中 二.输入 regsvr32 "C:\P ...