列表的一些常用操作符:

比较操作符、逻辑操作符、连接操作符、重复操作符、成员关系操作符

比较操作符:

>>> list1 = [123,456]

>>> list2 = [234,123]

>>> list1 > list2      #只比较第一个元素值的大小

False

>>> list3 = [123,456]

>>> (list1 < list2) and (list1 == list3)

True

>>> list4 = list1 + list2   #相当于append(),但不提倡这种方式,因为'+'是拼接符号,如果元素类型不一样是会报错的,建议如果追加元素使用append()

>>> list4

[123, 456, 234, 123]

>>> list3

[123, 456]

>>> list3 * 3              #把list3的元素打印3次,list3本身的值不会变

[123, 456, 123, 456, 123, 456]

>>> list3

[123, 456]

>>> list3 *= 3       相当于list3 = list3 * 3,把list3的元素3倍增加后再赋值给list3,list3的值会变化

>>> list3

[123, 456, 123, 456, 123, 456]

成员关系操作符:in 和 not in

>>> list5 = [123,['张三','李四'],456]

>>> 123 in list5

True

>>> '张三' in list5

False

>>> '张三' not in list5

True

>>> '张三' in list5[1]    #如果要引用列表中的列表,需要在列表后加上索引值

True

>>> list5[1][1]      #打印列表中的列表中的元素

'李四'

列表类型的内置函数

>>> dir(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']

count:计算参数在列表中出现的次数

>>> list3

[123, 456, 123, 456, 123, 456]

>>> list3.count(123)                #计算123在列表list3宗出现多少次

3

index:返回参数在列表中的位置

>>> list3.index(456)

1

>>> list3.index(123,1,4)           #从索引值1开始到索引值3(=4-1)查找参数123所在的位置(索引)

2

reverse:将整个列表翻转,是将列表中元素逆序排列

>>> list3.reverse()

>>> list3

[456, 123, 456, 123, 456, 123]

sort:用指定方式把列表元素进行排序

>>> list6 = [4,5,9,3,7,10,1,8]

>>> list6.sort()                       #默认是将列表中元素从小到大排序或按字母顺序排序

>>> list6

[1, 3, 4, 5, 7, 8, 9, 10]

>>> list6.sort(reverse=True)    #默认reverse=False,如果reverse=True,那么元素按大小排列后,会再进行逆序排列

>>> list6

[10, 9, 8, 7, 5, 4, 3, 1]

使用分片创建列表的拷贝

>>> list6

[10, 9, 8, 7, 5, 4, 3, 1]

>>> list7 = list6[:]           #把list6拷贝一份出来,赋值给list7

>>> list8 = list6              #变量list8指向list6的值,list8的值会随着list6的变化而变化

>>> list6.sort()

>>> list6

[1, 3, 4, 5, 7, 8, 9, 10]

>>> list7

[10, 9, 8, 7, 5, 4, 3, 1]

>>> list8

[1, 3, 4, 5, 7, 8, 9, 10]

---------------------分割线,哈哈哈----------------------

二、课后作业:

0.注意,这道题跟上节课的那道题有点儿不同,回答完请上机实验或参考答案。

old = [1, 2, 3, 4, 5]

new = old

old = [6]

print(new)

如果不上机操作,你觉得会打印什么内容?

[1,2,3,4,5]  因为变量old是重新赋值,而不是修改原有的元素,new还是指向的原存储区域

1.请问如何将下边这个列表的'小甲鱼'修改为'小鱿鱼'?

list1 = [1, [1, 2, ['小甲鱼']], 3, 5, 8, 13, 18]

>>> list1[1][2][0] = '小鱿鱼'

>>> list1

[1, [1, 2, ['小鱿鱼']], 3, 5, 8, 13, 18]

2.要对一个列表进行顺序排序,请问使用什么方法?

假使列表名为list2,对list2进行排序,list2.sort()

3.要对一个列表进行逆序排序,请问使用什么方法?

假使列表名为list2,对其进行逆序排序

list2.sort()      先正向排序

list2.reverse()   然后再逆向排序

或着 

list2.sort(reverse=True)  一步到位

4.列表还有两个内置方法没给大家介绍,不过聪明的你应该可以自己摸索使用的门道吧:copy() 和 clear()  

>>> list1

[1, [1, 2, ['小鱿鱼']], 3, 5, 8, 13, 18]

>>> list2 = list1.copy()

>>> list2

[1, [1, 2, ['小鱿鱼']], 3, 5, 8, 13, 18]

>>> list1.clear()

>>> list1

[]

5.你有听说过列表推导式或列表解析吗? 

列表推导式(List comprehensions)也叫列表解析,灵感取自函数式编程语言 Haskell。Ta 是一个非常有用和灵活的工具,可以用来动态的创建列表,语法如:  

[有关A的表达式 for A in B]  

>>> list1 =[x**2 for x in range(10)]

>>> list1

[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]

相当于

>>> list1 = []

>>> for x in range(10):

list1.append(x**2)

 >>> list1

[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]

问题:请先在 IDLE 中获得下边列表的结果,并按照上方例子把列表推导式还原出来。

>>> list1 = [(x, y) for x in range(10) for y in range(10) if x%2==0 if y%2!=0]

结果是

>>> list1

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

推导式为:

>>> list1 =[]

>>> for x in range(10):

    for y in range(10):

if x%2 == 0 and y%2 != 0:

list1.append((x,y))

>>> list1

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