上节"6.2 Python的list访问索引和切片"主要学习了Python下的List的访问技术:索引和切片的基础知识,这节将就List的索引index和切片Slice知识点做进一步的展开。
0.index必须大于0么?
list数据类型通过index访问某项数据项时,其index的值可以取负值,-1代表list列表最后一项数据,-2代表倒数第二项数据,以此类推。
>>> li1 = range(10)
>>> li1
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> li1[-1]
9
>>> li1[0:-2]
[0, 1, 2, 3, 4, 5, 6, 7]
>>> li1[-len(li1):-1]
[0, 1, 2, 3, 4, 5, 6, 7, 8]
1.slice步长
Python里的List数据类型在使用的时候,通常给出start和stop位置,比较常见。实际上List的Slice的标准语法规则应该是:
list_obj[start:stop:step]
这里的step是步长的意思。上边的意思是从start位置开始取数据,一直到stop-1这个位置结束,每隔step个数据项取一个数据。如果不指定step值,Python一般默认为+1。
>>> li1 = range(50)
>>> li1
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49]
>>> li2 = li1[::5]
>>> li2
[0, 5, 10, 15, 20, 25, 30, 35, 40, 45]
>>> li3 = li1[4:49:3]
>>> li3
[4, 7, 10, 13, 16, 19, 22, 25, 28, 31, 34, 37, 40, 43, 46]
>>>
上边代码第4行,li2列表的数据项是从li1里取得,以什么样的方式从li1里取呢?从li1的第0项数据开始一直到li1的最后一项结束,是全部都取回么?不是,从第0项开始,每隔5项数据取一个,所以取回的是0、5、10...45。代码第7行是从li1的第4项数据开始取数据,每隔3项数据取一个数据,所以依次取回第4项、第7项、第10项等数据。
>>> li4 = li1[4:49:-3]
>>> li4
[]
2.步长一定是正数么?
我们看下边的例子
>>> li1 = range(50)
>>> li4 = li1[4:49:-3]
>>> li4
[]
>>> li4 = li1[4:49:3]
>>> li4
[4, 7, 10, 13, 16, 19, 22, 25, 28, 31, 34, 37, 40, 43, 46]
>>> li4 = li1[49:4:-3]
>>> li4
[49, 46, 43, 40, 37, 34, 31, 28, 25, 22, 19, 16, 13, 10, 7]
>>>
例子说明,step也可以为负数,上边例子比较纠结的地方是代码第2行为何没有数据取回赋值给li4?其实很简单,在取li1时,限定了范围从li1列表的第4项开始取数据,到第48项数据结束,由于step=-3,那取回第一个数据应该是第4-3项数据即li1的第1项数据,但第1项数据不在4:49这个限定范围内,故无法取回数据并赋值给li4,故li4为空列表。理解了第2行的代码后再去理解第7行的代码就容易的多了,第7行的代码的意思从li1的第49项开始取数据,第二次去第49-3=46项的数据,一直取到第4-1=3项数据之间的所有满足条件的数据并赋值给li4。
3.list逆序
通过以上对list的start、stop和step的介绍,我们发现list太牛了!可以很轻松的使用list数据类型来完成C语言比较复杂的程序,例如用C语言实现对一个字符串数组的逆序操作,写出这个程序很复杂,如果用Python的list来实现一两行即可搞定!
>>> str1 = "www.jeapedu.com"
>>> li1 = list(str1)
>>> li1
['w', 'w', 'w', '.', 'j', 'e', 'a', 'p', 'e', 'd', 'u', '.', 'c', 'o', 'm']
>>> li2 = li1[-len(li1):-1]
>>> li2
['w', 'w', 'w', '.', 'j', 'e', 'a', 'p', 'e', 'd', 'u', '.', 'c', 'o']
>>> li3 = li1[-1:-len(li1)]
>>> li3
[]
>>> li3 = li1[-1:-len(li1):-1]
>>> li3
['m', 'o', 'c', '.', 'u', 'd', 'e', 'p', 'a', 'e', 'j', '.', 'w', 'w']
>>>
注:step默认情况下为1,len()函数可以测得list数据类型的长度,list()函数可将字符串专为list列表。
解释一下上边的小程序,代码第2行将str1字符串转换成list列表,并赋值给li1列表,代码第8行的li3为何没有数据呢?因为默认的step=1,在最后一项数据到第一项数据间这个访问内,从list的-1开始每隔1个已经超出了这个访问,故无法取得任何li1的数据项赋值给li3,而代码第11行去li1的范围为从最后一项(-1)开始,每隔负1项(-2、-3、-4...)都在-1到-len(li1)这个范围之内,故可以取回li1的数据项,由于步长绝对值为1,又是从li1最后一项开始取一直取到li1的第0项数据,故此时li3列表是li1列表的逆序列表。
有牛人说了,你上边的Python程序也太复杂了,Python有更简单的办法实现list的逆序,那就是直接调用Python提供的内建函数reverse(),恩,对!用reverse函数确实更简单!
>>> li5
['m', 'o', 'c', '.', 'u', 'd', 'e', 'p', 'a', 'e', 'j', '.', 'w', 'w', 'w']
>>> li5.reverse()
>>> li5
['w', 'w', 'w', '.', 'j', 'e', 'a', 'p', 'e', 'd', 'u', '.', 'c', 'o', 'm']
>>>
学Python吧!太强大了!
--->
Python学习入门基础教程(learning Python)--6.3 Python的list切片高级的更多相关文章
-
Python学习入门基础教程(learning Python)--5.6 Python读文件操作高级
前文5.2节和5.4节分别就Python下读文件操作做了基础性讲述和提升性介绍,但是仍有些问题,比如在5.4节里涉及到一个多次读文件的问题,实际上我们还没有完全阐述完毕,下面这个图片的问题在哪呢? 问 ...
-
Python学习入门基础教程(learning Python)--5.3 Python写文件基础
前边我们学习了一下Python下如何读取一个文件的基本操作,学会了read和readline两个函数,本节我们学习一下Python下写文件的基本操作方法. 这里仍然是举例来说明如何写文件.例子的功能是 ...
-
Python学习入门基础教程(learning Python)--3.3.3 Python逻辑关系表达式
在if分支判断语句里的条件判断语句不一定就是一个表达式,可以是多个(布尔)表达式的组合关系运算,这里如何使用更多的关系表达式构建出一个比较复杂的条件判断呢?这里需要再了解一下逻辑运算的基础知识.逻辑关 ...
-
Python学习入门基础教程(learning Python)--3.3.2 Python的关系运算
如果if的condition不用布尔表达式来做条件判断而采用关系表达式,实际上关系表达式运算的结果要么是True要么是False.下面我们先了解一些有关关系运算符的基础知识,如下表所示. 做个小程序测 ...
-
Python学习入门基础教程(learning Python)--5.1 Python下文件处理基本过程
Python下的文件读写操作过程和其他高级语言如C语言的操作过程基本一致,都要经历以下几个基本过程. 1. 打开文件 首先是要打开文件,打开文件的主要目的是为了建立程序和文件之间的联系.按程序访问文件 ...
-
Python学习入门基础教程(learning Python)--5.2 Python读文件基础
上节简单的说明了一下Pyhon下的文件读写基本流程,从本节开始,我们做几个小例子来具体展示一下Python下的文件操作,本节主要是详细讲述Python的文件读操作. 下面举一个例子,例子的功能是读取当 ...
-
Python学习入门基础教程(learning Python)--5 Python文件处理
本节主要讨论Python下的文件操作技术. 首先,要明白为何要学习或者说关系文件操作这件事?其实道理很简单,Python程序运行时,数据是存放在RAM里的,当Python程序运行结束后数据从RAM被清 ...
-
Python学习入门基础教程(learning Python)--8.3 字典常用的方法函数介绍
本节的主要讨论内容是有关dict字典的一些常用的方法函数的使用和范例展示. 1. clear清除字典数据 语法结构如下: dict_obj.clear() 示例代码如下: dict1 = {'web' ...
-
Python学习入门基础教程(learning Python)--2.2 Python下的变量基础
变量的基本概念,变量可以这样去理解,变量是一个值,这个值存储在计算机的内存里.以网购为例,您在选购傻商品的时候,是在不同页面里选不同的商品,选好一件点击“放入购物车”,选完了再点击去结帐,这些商品的价 ...
随机推荐
-
javascript中的闭包、模块与模块加载
一.前言 闭包是基于词法作用域( 和动态作用域对应,词法作用域是由你写代码时,将变量写在哪里来决定的,因此当词法分析器处理代码时,会保持作用)书写代码时所产生的自然结果,甚至不需要为了利用闭包而有意 ...
-
从C中变化过来的各种语言的printf输出格式
在c.php和shell中经常可以碰到printf的使用,特别是在php中printf的相关变种有好几个:print.printf.sprintf.vprintf.vsprintf 在这些语言 ...
-
第三节 ISBN 码 / ISSN 码
ISBN与ISSNEAN的用途很广,除了我国的商品条码CAN以及日本商品条码JAN外,目前国际认可的书籍代号与期刊号的条码,也都是由EAN变身而来的.书籍的国际认可代号称为国际标准书号(Interna ...
-
Java面试准备之集合框架
集合框架 Collection:List列表,Set集 Map:Hashtable,HashMap,TreeMap Collection 是单列集合 List 元素是有序的(元素存取是有序).可重复 ...
-
HashTable &; HashMap &; ConcurrentHashMap 原理与区别
一.三者的区别 HashTable HashMap ConcurrentHashMap 底层数据结构 数组+链表 数组+链表 数组+链表 key可为空 否 是 否 value可为空 否 是 否 ...
-
Java并发编程笔记之CopyOnWriteArrayList源码分析
并发包中并发List只有CopyOnWriteArrayList这一个,CopyOnWriteArrayList是一个线程安全的ArrayList,对其进行修改操作和元素迭代操作都是在底层创建一个拷贝 ...
-
python退出多重循环
假设一段python程序有多重循环,我们都知道在一个循环当中,用break是退出当前的循环,然后继续下一次循环,但是如何才能跳出多重循环呢,实际就是结束所有的循环. 思路1::可以定义一个异常类,在需 ...
-
秒杀多线程第五篇 经典线程同步 关键段CS
本文首先介绍下如何使用关键段,然后再深层次的分析下关键段的实现机制与原理. 关键段CRITICAL_SECTION一共就四个函数,使用很是方便.下面是这四个函数的原型和使用说明. 函数功能:初始化 函 ...
-
seleniumIDE的实践
浏览器:1.Firefox setup35.0.12.安装完成后设置菜单栏---安装完浏览器,鼠标定位在浏览器的状态栏,然后点击鼠标右键,点击勾选菜单栏,这时候就有菜单栏出现了 3.关闭浏览器自动更新 ...
-
洛谷八连测R5题解
woc居然忘了早上有八连测T T 还好明早还有一场...今天的题除了T3都挺NOIP的... T1只需要按横坐标第一关键字,纵坐标第二关键字排序一个一个取就好了... #include<iost ...