七、列表——list

Python的列表是一种内置的数据类型,是由Python的基本数据类型组成的有序的集合。有点类似C语言的数组,但与数组不同的是,Python在定义列表的时候不用指定列表的容积(长度),可根据需要任意扩展,另外列表的内的元素可以是不同的数据类型,当然既然是任何数据类型,当然也包括另一个列表也就是嵌套。Python中列表使用中括号[]括起来,例如[1,2,True,'ABC',[5,'678']].

1、列表的切片

通字符串一样列表也支持切片操作,例如我们有一个列表A_list = ['Michael', 'Bob', 'Tracy']

1)列表中索引号为n的元素(一样是从0开始计数哦)

>>> A_list[]
'Bob'

2)从第m个元素到第n个元素

>>> A_list[:]
['Michael', 'Bob']

3)从第m个元素到第n个元素,步长为p(也就是每隔p-1个字符)

>>> A_list[::]
['Michael', 'Tracy']

说明:同字符串一样,列表的切片同样省略索引号和支持复数,用法与字符串一样,这里就不复述了。

2、列表的内置方法

Python中查看一个对象的内置方法和属性可以使用内置的dir方法,比如我们查看列表A_list的方法和属性

>>> dir(A_list)
['__add__', '__class__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__gt__', '__hash__', '__iadd__', '__imul__', '__init__', '__iter__', '__le__', '__len__', '__lt__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__reversed__', '__rmul__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'append', 'clear', 'copy', 'count', 'extend', 'index', 'insert', 'pop', 'remove', 'reverse', 'sort']

常用的方法有:

>>> A_list = ['Michael', 'Bob', 'Tracy']
>>> A_list.append('Peter') # 在末尾插入一个新的元素
>>> A_list
['Michael', 'Bob', 'Tracy', 'Peter']
>>> A_list.insert(1, 'Jack') # 在指定位置(索引号)插入一个新的元素
>>> A_list
['Michael', 'Jack', 'Bob', 'Tracy', 'Peter']
>>> A_list.pop() # 删除最后一个元素,并返回该元素,如果列表已经为空在执行pop方法会报错,类似IndexError: pop from empty list
'Peter'
>>> A_list
['Michael', 'Jack', 'Bob', 'Tracy']
>>> A_list.remove('Jack') # 删除指定的元素,注意这里接受的参数是元素,而不是索引号,如果元素不存在则报错,类似ValueError: list.remove(x): x not in list
>>> A_list
['Michael', 'Bob', 'Tracy']
>>> A_list.index('Bob') # 返回指定元素所在位置的索引号,如果元素不存在则报错ValueError: 'dafda' is not in list
1
>>> A_list.sort() # 排序,注意Python3已经不支持不同类型数据的排序,如果列表内元素的类型不一致,就会报错,类似TypeError: unorderable types: str() < list()
>>> A_list
['Bob', 'Michael', 'Tracy']
>>> A_list.reverse() # 翻转列表的元素位置
>>> A_list
['Tracy', 'Michael', 'Bob']
>>> B_list = ['Jack','Peter']
>>> A_list.extend(B_list) # 将另一个列表的每一个元素追加到列表的末尾,注意与append不同,append会把另一列表当成一个元素追加到列表的末尾
>>> A_list
['Tracy', 'Michael', 'Bob', 'Jack', 'Peter']
>>> A_list.count('Bob') # 返回列表的某一个元素重复的个数,如果元素不存在返回0,不会报错
1

我们上面说index方法和remove方法只能返回或删除第一查找到的元素,如果一个列表中重复出现多次我们如何处理呢,这时候我们可以这么处理

全部删除:原理就是先求出出现了多少次,然后通过循环删除

#!/usr/bin/env python
# coding:utf-8
name_list = ['Michael', 'Jack', 'Bob', 'Tracy', 'Peter', 'Jack'] # 这里有两'Jack'
# 返回所有'Jack'的索引
for i in range(name_list.count('Jack')):
name_list.remove('Jack')
print(name_list)

查询所有的索引号,原理就是先求出一共出现了多少次,第一次直接查找返回说因,从第二次开始开始,从上一次的索引位置的下一个位置进行切片,然后再进行查,那么这一次的索引号就是上一次的索引号+加上本次的索引+1,依次类推

#!/usr/bin/env python
# coding:utf-8
name_list = ['Jack', 'Michael', 'Jack', 'Bob', 'Tracy', 'Peter', 'Jack'] # 这里有三个'Jack'
# 返回所有'Jack'的索引
index_num = 0 # 定义初始索引号
index_list = [] # 定义用来存储索引号的列表
for i in range(name_list.count('Jack')):
if i != 0: # i不等于0也就是说不是第一次查找
index_num = name_list[index_num+1:].index('Jack') + index_num + 1
else: # 否则就是第一次查找,直接返回索引号即可
index_num = name_list.index('Jack')
index_list.append(index_num) # 将索引号追加到index_list中
print(index_list)

八、元祖——tuple

元祖和列表非常类似,但是元祖一旦初始化就不能修改,所以元祖除了可以切片外没有列表的那些方法。

但是我们所说的元祖的不可变不是绝对的,也可以是“可变的”,那就是元祖里的元素是其他可变的数据类型,如列表等

例如:t = ('a', 'b', ['A', 'B'])

注意里面列表,我们要对这个列表进行一些修改操作:

>>> t = ('a', 'b', ['A', 'B'])
>>> t[2][0] = 'X'
>>> t
('a', 'b', ['X', 'B'])
>>> t[2].append('C')
>>> t
('a', 'b', ['X', 'B', 'C'])

可以看出如果元祖里有可变数据类型的元素,那么该元素是依然可以修改的,这使得元祖貌似被修改了,其实并没有修改,因为Python一切皆指针。

我的Python成长之路---第一天---Python基础(6)---2015年12月26日(雾霾)的更多相关文章

  1. 我的Python成长之路---第一天---Python基础(1)---2015年12月26日(雾霾)

    2015年12月26日是个特别的日子,我的Python成之路迈出第一步.见到了心目中的Python大神(Alex),也认识到了新的志向相投的伙伴,非常开心. 尽管之前看过一些Python的视频.书,算 ...

  2. 我的Python成长之路---第一天---Python基础(作业2:三级菜单)---2015年12月26日(雾霾)

    作业二:三级菜单 三级菜单 可一次进入各个子菜单 思路: 这个题看似不难,难点在于三层循环的嵌套,我的思路就是通过flag的真假来控制每一层的循环的,简单来说就是就是通过给每一层循环一个单独的布尔变量 ...

  3. 我的Python成长之路---第一天---Python基础(2)---2015年12月26日(雾霾)

    三.数据类型 Python基本类型(能够直接处理的数据类型有以下几种)主要有5种 1.整数(int) Python可以处理任意大小的整数,当然包括负整数,在程序中的表示方法和数学上的写法一模一样,例如 ...

  4. 我的Python成长之路---第一天---Python基础(4)---2015年12月26日(雾霾)

    五.数据运算与数据运算符 1.算术运算符 算术运算符 运算符 描述 示例 + 加法 >>> 14 - 5 9 - 减法 >>> 14 - 5 9  *  乘法 &g ...

  5. 我的Python成长之路---第一天---Python基础(5)---2015年12月26日(雾霾)

    六.流程控制 与C语言不通的事Python的流程控制的代码块不是用{}花括号表示的,而是用强制缩进来,而且缩进必须一致,官方推荐是使用4个空格,不建议使用使用tab(制表符)做缩进,一是不同的系统ta ...

  6. 我的Python成长之路---第一天---Python基础(3)---2015年12月26日(雾霾)

    四.变量和常量 变量是用来存储程序运行期间需要临时保存可以不断改变的数据的标识符.Python有自身的内存回收机制,所以在开发过程中不用考虑变量的销毁等 Python中的变量名命名有如下规则: 1.变 ...

  7. 我的Python成长之路---第一天---Python基础(作业1:登录验证)---2015年12月26日(雾霾)

    作业一:编写登录接口 输入用户名密码 认证成功系那是欢迎信息 输错三次后锁定 思路: 1.参考模型,这个作业我参考了linux的登录认证流程以及结合网上银行支付宝等锁定规则 1)认证流程参考的是Lin ...

  8. python成长之路第一篇(5)文件的基本操作

    一.三元运算 我们在上章学习的if,,else,,有一种简便的方法 他的表达式是这样的:变量 = 值1 if 条件 else 值2 解释过来就是如果aaa等于sss则输出值1否则输出值2 二.类的概念 ...

  9. PYthon成长之路第一篇(1)__字符串初识

    今天一起走进python的代码世界,一起领悟python的魅力 在很多学习python的书中都会以 print  “Hello,world!” 这样的而一个程序为开始,那么其中的 hello,worl ...

随机推荐

  1. 也谈.NET MVC 2 + ExtJS的部署问题

    由于业务需要,笔者刚进到一个项目组,由于没有美工,前台采用ExtJs + MVC 2 ,迭代1的项目做的还算比较顺利,至少在本机上是运行没有任何问题的, 但是为了给客户演示,我兴高采烈的将网站部署在I ...

  2. 阿里Android一面(校招)

    4.8号晚上8点多接到了阿里一面的电话,面试官人很好,和我聊了半个多小时.我面的是无线事业部,就是做淘宝客户端的那个部门.面试问的都很基础,刚开始问了hashmap和快速排序.接着就是问Android ...

  3. 使用PowerShell 命令集进行SQL Server 2012 备份和还原

    最近心相不错,所以打算翻译一些英文文档做福利,原文在此,翻译有不足的地方还请各位兄弟指点. 讨论什么是DBA最重要的工作的时候,你最常听到就是一条就是DBA只要做好备份和恢复.事实如此,如果你不做备份 ...

  4. Orchard 添加搜索栏

    Orchard 提供索引和搜索的功能. 索引功能需要开启 Indexing 模块, 同时我们要开启Lucene 模块(做实际检索工作的东西). 然后还要开启Search模块(调用Lucene 查询然后 ...

  5. 【转】Nginx+Tomcat搭建高性能负载均衡集群

    最近对负载均衡比较感兴趣,研究了公司的负载均衡的配置,用的是阿里的SLB,相当于不用运维,只需要在后台进行简单的配置就能完成Tomcat的负载均衡,索性在网上找了几篇文章去尝试搭建一个集群,然而很多都 ...

  6. WEB ICON 的探讨

    一般考虑到webicon 就是cssSprite和自定义font:本文基于下述而总结和进行分析,如有笔误有望指出,谢谢 在线教程:用字体在网页中画ICON图标 http://www.imooc.com ...

  7. Android Studio does not point to a valid jvm

    环境变量 JAVA_HOME的值,去掉后面的分号,一般情况下就可以启动

  8. ThinkPHP第五天(提交类型判定常量IS_POST等,错误页面种类,Model实例化方式,模板中使用函数,foreach循环,模板中.语法配置)

    1.IS_GET.IS_POST.IS_PUT.IS_DELETE.IS_AJAX常量,方便快捷实现各个判断. 在Action类中还可以使用$this->isPost()等进行判断. 2.错误页 ...

  9. Python学习之路——迭代器、生成器、算法基础、正则

    一.迭代器: 迭代器是访问集合元素的一种方式. 迭代器对象是从集合的第一个元素开始访问,直到所有的元素被访问完结束. 迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退. 另外,迭代 ...

  10. LinkList Operation

    链表典型数据结构: #define ElemType int typedef struct LinkNode{ ElemType value; struct LinkNode* next; }; 相比 ...