1、Python 中的数组

形式:

  • 用list和tuple等数据结构表示数组

  一维数组:list=[1,2,3,4]

  二维数组:list=[[1,2,3],[4,5,6],[7,8,9]]

  • 用array模块:array模块需要加载,而且运用的较少

  通过array函数创建数组(数组中的元素可以不是同一种类型),array.array('B',range(5))   >>array('B',[1,2,3,4,5])

  提供append、insert和read等函数

标准安装的Python中用列表(list)保存一组值,可以用来当作数组使用,不过由于列表的元素可以是任何对象,因此列表中所保存的是对象的指针。这样为了保存一个简单的[1,2,3],需要有3个指针和三个整数对象。对于数值运算来说这种结构显然比较浪费内存和CPU计算时间。

此外Python还提供了一个array模块,array对象和列表不同,它直接保存数值,和C语言的一维数组比较类似。但是由于它不支持多维,也没有各种运算函数,因此也不适合做数值运算。

NumPy的诞生弥补了这些不足,NumPy提供了两种基本的对象:ndarray(N-dimensional array object)和 ufunc(universal function object)。ndarray(数组)是存储单一数据类型的多维数组,而ufunc则是能够对数组进行处理的函数。

(来自链接http://old.sebug.net/paper/books/scipydoc/numpy_intro.html)

2、ndarray

ndarray是Numpy中的基本数据结构,所有元素是同一种类型,优点:节省内存和提高CPU计算时间,有丰富的函数。

0:作用对象是index; 1:作用对象是columns。

(1)数组的创建:

import numpy as np

①array函数创建:x=np.array([(1,2,3),(4,5,6)])

    创建一维数组:np.array([元素1,元素2,……])

    创建二维数组:np.array ( [ [ 元素1,元素2……] , [ 元素1,元素2,…… ] ,[ ] , [ ] ] )

②arange:           x=np.arange(1,5,0.5)      >>array([1.,1.5,2.,2.5,3.,3.5,4.,4.5])

③random:          x=np.random.random((2,2))   >>array([[0.7999243,0.3454323].[0.3546543,0.4634535]])

④linspace:         x=np.linspace(1,2,5,endpoint=False)   >>array([1.,1.2,1.4,1.6,1.8])

⑤ones:              x=np.ones([2,3])   >>array([[1.,1.,1.],[1.,1.,1.]])

⑥zeros:             x=np.zeros((2,2))  >>array([[0.,0.],[0.,0.]])

⑦fromfunction:  x=np.fromfunction(lamda i,j:(i+1)*(j+1),(9,9))

结果为9*9乘法表。array([[1,2,3,4,5,6,7,8,9],

[2,4,6,8,10,12,14,16,18],

[3,6,9……]

……

[9,18,……,81]])

(2)数组的操作:

①array[1]   :选择第二行所有元素

array[0:2]:选择从第一行到第二行的所有元素(索引2不包括,即第三行)

array[:,[0,1]]:选择所有行的第一列和第二列的元素

array[1,[0,1]]:选择第二行第1列和第2列的元素

②shape:数组的维数,shape[0]取行数,shape[1]取列数。

③size:元素总个数

④reshape():改变数组的大小。但是原数组不变,即aArray不变,变化结果在bArray

aArray=np.array([[1,2,3],[4,5,6]])   bArray=aArray.reshape(1,6)

>> aArray=array([[1,2,3],[4,5,6]])

>> bArray=array([[1,2,3,4,5,6]])

⑤resize():改变数组的大小。原数组改变了,即aArray变了

aArray.resize(1,6)

>> aArray= array([[1,2,3,4,5,6]])

⑥vstack():垂直方向拼接。

cArray=np.array([[7,8,9]])

np.vstack((aArray,cArray))

>>array([[1,2,3],

[4,5,6],

[7,8,9]])

⑦hstack():水平方向拼接。

np.hstack((aArray,cArray))

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

⑧+:(两个大小不同的数组相加,是一种广播的思想)

aArray+cArray   >>array([[8,10,12],[11,13,15]])

⑨sort(): 排序 ,一维数组x排序,x.sort()

    二维数组y=([[3,1,2],[6,3,1]])排序是对每一行进行排序,y.sort(),结果为y=([[1,2,3],[1,3,6]])

统计运算:

①sum():所有元素的求和,aArray.sum()

②sum(axis=0):列求和

③min():所有元素最小值,aArray.min()

④argmax():返回最大值的索引

⑤mean():所有元素的均值

⑥var():方差

⑦std():标准差

线性代数:np.linalg模块中的函数

①np.linalg.det(x):行列式

②np.linalg.inv(x):逆矩阵

③np.dot(x,x):x的内积

④np.linalg.solve():多元一次方程组求根

⑤np.linalg.eig():求特征值和特征向量

ufunc函数:

同样的计算numpy的通用计算比math计算的要快。

Vectorize函数:对numpy数组中的每一个元素应用一个函数。
a = np.array([[[1, 2], [1]],
[[2, 3, 3], [3, 4]]
])
print(a.shape)
count_fun = np.vectorize(lambda x: len(x))
print(count_fun(a))

Python笔记6----数组的更多相关文章

  1. python笔记 - day3

    python笔记 - day3 参考:http://www.cnblogs.com/wupeiqi/articles/5453708.html set特性: 1.无序 2.不重复 3.可嵌套 函数: ...

  2. python笔记05

    python笔记05 数据类型 上个笔记知识点总结: 列表中extend特性:extend,(内部循环,将另外一个列表,字符串.元组添加到extend前的列表中) li.extend(s),将s中元素 ...

  3. Python笔记之不可不练

    如果您已经有了一定的Python编程基础,那么本文就是为您的编程能力锦上添花,如果您刚刚开始对Python有一点点兴趣,不怕,Python的重点基础知识已经总结在博文<Python笔记之不可不知 ...

  4. boost.python笔记

    boost.python笔记 标签: boost.python,python, C++ 简介 Boost.python是什么? 它是boost库的一部分,随boost一起安装,用来实现C++和Pyth ...

  5. 20.Python笔记之SqlAlchemy使用

    Date:2016-03-27 Title:20.Python笔记之SqlAlchemy使用 Tags:python Category:Python 作者:刘耀 博客:www.liuyao.me 一. ...

  6. Python笔记——类定义

    Python笔记——类定义 一.类定义: class <类名>: <语句> 类实例化后,可以使用其属性,实际上,创建一个类之后,可以通过类名访问其属性 如果直接使用类名修改其属 ...

  7. 13.python笔记之pyyaml模块

    Date:2016-03-25 Title:13.Python笔记之Pyymal模块使用 Tags:Python Category:Python 博客地址:www.liuyao.me 作者:刘耀 YA ...

  8. 8.python笔记之面向对象基础

    title: 8.Python笔记之面向对象基础 date: 2016-02-21 15:10:35 tags: Python categories: Python --- 面向对象思维导图 (来自1 ...

  9. python笔记 - day8

    python笔记 - day8 参考: http://www.cnblogs.com/wupeiqi/p/4766801.html http://www.cnblogs.com/wupeiqi/art ...

  10. python笔记 - day7-1 之面向对象编程

    python笔记 - day7-1 之面向对象编程 什么时候用面向对象: 多个函数的参数相同: 当某一些函数具有相同参数时,可以使用面向对象的方式,将参数值一次性的封装到对象,以后去对象中取值即可: ...

随机推荐

  1. rmq算法,利用倍增思想

    RMQ问题ST算法  /*  RMQ(Range Minimum/Maximum Query)问题:      RMQ问题是求给定区间中的最值问题.当然,最简单的算法是O(n)的,但是对于查询次数很多 ...

  2. [bzoj3282]Tree_LCT

    Tree bzoj-3282 题目大意:给你n个点m个操作.更改单点权值,加边,删边:查询路径异或和. 注释:$1\le n,m\le 10^5$ 想法:看到了加边删边,果断想到LCT维护.至于路径异 ...

  3. 洛谷 P3252 [JLOI2012]树

    P3252 [JLOI2012]树 题目描述 在这个问题中,给定一个值S和一棵树.在树的每个节点有一个正整数,问有多少条路径的节点总和达到S.路径中节点的深度必须是升序的.假设节点1是根节点,根的深度 ...

  4. 自己定义ShareSDK分享平台界面

    自己定义ShareSDK分享平台界面 执行效果图: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvZ2FvX2NodW4=/font/5a6L5L2T/fo ...

  5. Delicious Apples (hdu 5303 贪心+枚举)

    Delicious Apples Time Limit: 5000/3000 MS (Java/Others)    Memory Limit: 524288/524288 K (Java/Other ...

  6. 王立平--Http中Get() 与 Post()的差别?

    Http协议是基于TCP协议的,而TCP协议是一种有连接.可靠的传输协议.假设丢失的话,会重传.所以这种话,就 不会有数据的丢失了. 而Http协议有三种方法.Get,Post,Head方法.可是用的 ...

  7. Linux实时查看日志,访问前10IP 和相关命令

    Nginx日志分析可以获得很多有用的信息,现在来试试最基本的,获取最多访问的前10个IP地址及访问次数. 既然是统计,那么awk是必不可少的,好用而高效. 命令如下: awk '{a[$1] += 1 ...

  8. 【HDOJ 1009】 CRB and String

    [HDOJ 1009] CRB and String 每组两个串s t 仅仅由小写字母组成 问从s能不能变成t 改变的操作为选一个字符 在后面加上一个与所选字符不同的字符 这样的操作能够做无数次 问能 ...

  9. cocos2dx 自己主动绑定js

    依照教程把全部资源下载好后....... 找到cocos2dx project下的tools/bindings-generator/test 发现里面有test.sh , test.ini , 去掉s ...

  10. ASP.NET MVC2 Web项目中公用类库的问题

    ASP.NET WEB窗体 网站中,加入公用类文件的话,系统会很自动并殷勤的问你,说要不要把它存放在文件夹 App_Code 里.一旦加入,全站都可以很方便地加以使用,一点问题没有. 这种习以为常的方 ...