从机器学习学python(三) ——数组冒号取值与extend

从机器学习学python(三)——数组冒号取值与extend

(原创内容,转载请注明来源,谢谢)

一、数组冒号取值

1、 小白级别

python的特有取值方式,假设数组a = [0,1,2,3,4],则:

b=a[:3]表示b取数组a第四个元素之前的元素,即b=[0,1,2]

c=a[:-1]则表示取a最后一个元素前面的所有元素,即c=[0,1,2,3]

原理是因为冒号前面带0的可以省略掉。

2、困难级别

b=array(
  [
    [
      [ 0,  1, 2,  3],
     [4,  5, 6,  7],
     [8,  9,  10, 11]
      ],
  [
      [12, 13, 14, 15],
     [16, 17,18, 19],
     [20, 21, 22, 23]
    ]
  ]
)

即,b是三维数组,每个维度上的元素个数分别是2、3、4,在不用冒号取值的情况下,b[0][0][0]即表示第一个元素0,b[0]表示取b数组第一个维度上的第一个数组元素。

当使用冒号取值,规则为:【第1维起点:终点:步长,第2维 ...,第3维】

取出整个b数组的写法为b[0:2:1,0:3:1, 0:4:1],拿第一维举例,0:2:1,表示对于第一维而言,取起点第1个元素(数组下标是0)、终点第2个元素(终点下标是1)、步长是1(即每个元素都取,如果写2表示隔一个元素取一个元素)。另外可以看到,这里最后取到的值,是包含了起点的元素,但是不包含终点的元素。

3、大师级别

还是用上面的数组b。

1)步长为1可以省略, b[0:2:,0:3:, 0:4:] 和上面的b[0:2:1, 0:3:1, 0:4:1]等效(注:当然和步长一起的冒号也可以省略,成如下格式b[0:2, 0:3, 0:4],为了便于理解我们还是先保留这个冒号)

2)终点为自然终点,可以省略,b[0::, 0::, 0::](注:可以省略成b[0:,0:,0:],不能省略成b[0,0,0])

3)起点为自然起点,可以省略,b[::,::,::](注:可以省略成b[:,:,:],不能省略成b[,,])

4、骨灰级

b[::,::,::] ,最右边的,如果都是省略形式,那么也可以省略,从右边开始省略,先是冒号省略b[::,::,],然后是逗号省略b[::,::],依次b[::,],b[::],b[:](注:不能省略成b[]),最后就是省略成b了。

如果右边不是简略形式,就不能省略,像b[::,::,::2]就不能省略成b[,,::2]

如果想成左边开始省略的,前面可以加... 即b[..., ::2]

5、个人体会

这种东西,建议写的时候最好不要用省略,实在想用一定要写注释,不然过两天自己都不知道在写什么了。

写这个的主要目的在于,有的书上会涉及到省略形式。

二、extend与append

1.append()

向列表尾部追加一个新元素,列表只占一个索引位,在原有列表上增加

2.extend()

向列表尾部追加一个列表,将列表中的每个元素都追加进来,在原有列表上增加

3.+

直接用+号看上去与用extend()一样的效果,但是实际上是生成了一个新的列表,存这两个列表的和,只能用在两个列表相加上。(即需要写出C=A+B,单纯写式子A+B,则没有变量来保存结果)

4.+=

效果与extend()一样,向原列表追加一个新元素,在原有列表上增加。

综上,对于一个数组x,要把下标是index的元素(index在x的范围内)抽走,返回剩下的元素,可以如下方式:

y=x[:index]
y.extend(x[index+1:])

——written by linhxx 2018.01.06

原文发布于微信公众号 - 决胜机器学习(phpthinker)

原文发表时间:2018-01-06

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏编舟记

Monad

什么是函数(Function)? 函数表达的映射关系在类型上体现在特定类型(proper type)之间的映射。

715
来自专栏于晓飞的专栏

读 Java TimSort算法 源码 笔记

本来准备看Java容器源码的。但是看到一开始发现Arrays这个类我不是很熟,就顺便把Arrays这个类给看了。Arrays类没有什么架构与难点,但Arrays...

722
来自专栏鸿的学习笔记

python的迭代器和生成器

迭代是数据处理的基础,迭代可以理解为是一种惰性求值。在python里迭代器和生成器是一回事,使用的是yield关键字。

471
来自专栏老马说编程

(47) 堆和PriorityQueue的应用 / 计算机程序的思维逻辑

45节介绍了堆的概念和算法,上节介绍了Java中堆的实现类PriorityQueue,PriorityQueue除了用作优先级队列,还可以用来解决一些别的问题,...

17710
来自专栏逆向技术

逆向课程第四讲逆向中的优化方式,除法原理,以及除法优化上

           逆向课程第四讲逆向中的优化方式,除法原理,以及除法优化上 除法原理,涉及到了数学公式,而且在汇编中的体现形式也有10几种 这里首先讲解前4...

2138
来自专栏韦弦的微信小程序

Swift 实现strStr() - LeetCode

当 needle 是空字符串时,我们应当返回什么值呢?这是一个在面试中很好的问题。

732
来自专栏菜鸟前端工程师

JavaScript学习笔记023-对象方法0包装对象0静态属性

682
来自专栏Java3y

十道算法题[二]

前言 清明不小心就拖了两天没更了~~ 这是十道算法题的第二篇了~上一篇回顾:十道简单算法题 最近在回顾以前使用C写过的数据结构和算法的东西,发现自己的算法和数据...

3069
来自专栏灯塔大数据

每周学点大数据 | No.24二叉搜索树回顾(一)

No.24期 二叉搜索树回顾(一) Mr. 王:接下来我们谈一谈外存查找结构。内存中的查找结构最典型的就是二查搜索树了。这里我们先来简单地认识一下关于二叉树...

3295
来自专栏CodingBlock

Java数据结构和算法总结-字符串相关高频面试题算法

前言:周末闲来无事,在七月在线上看了看字符串相关算法的讲解视频,收货颇丰,跟着视频讲解简单做了一下笔记,方便以后翻阅复习同时也很乐意分享给大家。什么字符串在算...

2710

扫码关注云+社区