码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2015-12-29 14:16:59      阅读:242      评论:0      收藏:0      [点我收藏+]

标签:

    七、列表——list

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

    1、列表的切片

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

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

>>> A_list[1]
Bob

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

>>> A_list[0:2]
[Michael, Bob]

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

>>> A_list[0:3:2]
[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日(雾霾)

标签:

原文地址:http://www.cnblogs.com/zhangxiaxuan/p/5085430.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!