Python操作列表的常用方法

 下面列出列表常用的方法操作列表以及小例子:
 
1.  Append
     在列表末尾添加元素,需在列表末尾添加元素,需要注意几个点:
     A. append中添加的参数是作为一个整体
    
1 >>> name = list("scott")
2 >>> name
3 ['s', 'c', 'o', 't', 't']
4 >>> name.append(list(" tiger"))
5 >>> name
6 ['s', 'c', 'o', 't', 't', [' ', 't', 'i', 'g', 'e', 'r']]
得到的值不是:['s', 'c', 'o', 't', 't', ' ', 't', 'i', 'g', 'e', 'r']
如果想要这种的追加方式,可以试试分片赋值(或者下面说到的extend方法):
1 >>> name = list("scott")
2 >>> name
3 ['s', 'c', 'o', 't', 't']
4 >>> name[len(name):] = list(" tiger")      #从末尾追加
5 >>> name
6 ['s', 'c', 'o', 't', 't', ' ', 't', 'i', 'g', 'e', 'r']
B.append一次性只能添加一个元素
 1 >>> name = list("scott")
 2 >>> name
 3 ['s', 'c', 'o', 't', 't']
 4 >>> name.append("A","B")        #添加多个元素即将报错
 5 Traceback (most recent call last):
 6   File "<stdin>", line 1, in ?
 7 TypeError: append() takes exactly one argument (2 given)
 8 >>> name.append("A")
 9 >>> name
10 ['s', 'c', 'o', 't', 't', 'A']

 

2. Count

     统计某个元素在列表中出现的次数
 1 >>> name = list("scott")
 2 >>> name
 3 ['s', 'c', 'o', 't', 't']
 4 >>> name.count('s')
 5 1
 6 >>> name.count("t")
 7 2
 8 >>> name.count("A")
 9 0
10 >>> name.append(list("Python"))
11 >>> name
12 ['s', 'c', 'o', 't', 't', ['P', 'y', 't', 'h', 'o', 'n']]
13 >>> name.count(['P', 'y', 't', 'h', 'o', 'n'])
14 1

 

3. Extend

   在原列表追加另一个序列的中的多个值

1 >>> name = list("scott")
2 >>> name
3 ['s', 'c', 'o', 't', 't']
4 >>> name.extend(list(" tiger"))
5 >>> name
6 ['s', 'c', 'o', 't', 't', ' ', 't', 'i', 'g', 'e', 'r']
当然,我们可以用分片赋值来实现:
1 >>> name = list("scott")
2 >>> name
3 ['s', 'c', 'o', 't', 't']
4 >>> name[len(name):] = list(" tiger")
5 >>> name
6 ['s', 'c', 'o', 't', 't', ' ', 't', 'i', 'g', 'e', 'r']
这时小伙伴们会想到,我们可以直接用操作符"+"嘛,还方便些:
1 >>> name = list("scott")
2 >>> pwd  = list(" tiger")
3 >>> name + pwd
4 ['s', 'c', 'o', 't', 't', ' ', 't', 'i', 'g', 'e', 'r']
5 >>> name
6 ['s', 'c', 'o', 't', 't']
从这三种方式操作的输出,可以看出:
extend和分片赋值都是修改原列表,相对而言,extend可读性强些,而操作符"+"是生成一个新的列表,不影响原列表,如果
我们需要生成新列表而不影响原列表,就可以用操作符"+"。
 
4.Index
从列表中找出某个值 第一个 (注意是第一个)匹配项的索引位置
 1 >>> name = list("scott")
 2 >>> name
 3 ['s', 'c', 'o', 't', 't']
 4 >>> name.index('t')    ##第一个字母t的索引位置是3
 5 3   
 6 >>> name.index('a')
 7 Traceback (most recent call last):
 8   File "<stdin>", line 1, in ?
 9 ValueError: list.index(x): x not in list
10 >>> 'a' in name
11 False
12 >>> 'a' not in name
13 True
从输出可以看出,index找的是第一个匹配项的索引位置,而如果查找的元素不在列表中,会报错(返回-1会不会好一点呢?),当然如果想避免报
错,我们可以先用in操作,判断某个元素是否在某个列表中,如果在的话,然后进行index操作。
 
5. Insert
    用于将对象插入到列表中,俩个参数,第一个是索引位置,第二个插入的元素对象。
1 >>> name = list("scott")
2 >>> name
3 ['s', 'c', 'o', 't', 't']
4 >>> name.insert(2,'tiger')     ##在索引为2的地方插入字符串tiger  
5 >>> name
6 ['s', 'c', 'tiger', 'o', 't', 't']
我们也可以用分片赋值:
1 >>> name = list("scott")
2 >>> name
3 ['s', 'c', 'o', 't', 't']
4 >>> name[2:2] = ['tiger']
5 >>> name
6 ['s', 'c', 'tiger', 'o', 't', 't']
7 >>> name[2:2] = 'tiger'
8 >>> name
9 ['s', 'c', 't', 'i', 'g', 'e', 'r', 'tiger', 'o', 't', 't']
这里需要注意的是,如果是插入一个元素,需要用[]括起来,不然,直接用字符串的话,是插入字符串的列表,在索引位置之后添加。
当然,用insert的可读性比分片赋值强。
 
6. Pop
    移除列表中的一个元素(最后一个元素),并返回该元素的值
 1 >>> name = list("scott")
 2 >>> name
 3 ['s', 'c', 'o', 't', 't']
 4 >>> name.pop()
 5 't'
 6 >>> name
 7 ['s', 'c', 'o', 't']
 8 >>> name.append("t")
 9 >>> name
10 ['s', 'c', 'o', 't', 't']
分片赋值模拟pop:
1 >>> name = list("scott")
2 >>> name
3 ['s', 'c', 'o', 't', 't']
4 >>> name[len(name)-1:] = []
5 >>> name
6 ['s', 'c', 'o', 't']
这上面用pop和append模拟了栈的先进先出LIFO。
 
7. Remove
   移除列表中某个值的第一匹配项: 如果有俩个相等的元素,就只是移除匹配的一个元素,如果某元素不存在某列表中,便会报错,而且一次性只能
   移除一个元素。
 1 >>> name = list("scott")
 2 >>> name
 3 ['s', 'c', 'o', 't', 't']
 4 >>> name.remove("t")    #去掉第一个t
 5 >>> name
 6 ['s', 'c', 'o', 't']
 7 >>> name.remove("A")    #不存在会报错
 8 Traceback (most recent call last):
 9   File "<stdin>", line 1, in ?
10 ValueError: list.remove(x): x not in list
11 >>> "A" not in name
12 True
13 >>> name.remove("s","c")  #一次只能移除一个元素
14 Traceback (most recent call last):
15   File "<stdin>", line 1, in ?
16 TypeError: remove() takes exactly one argument (2 given)

 

8.Revense

   将列表中的元素反向

1 >>> name = list("scott")
2 >>> name
3 ['s', 'c', 'o', 't', 't']
4 >>> name.reverse()
5 >>> name
6 ['t', 't', 'o', 'c', 's']

 

9. Sort & Sorted

    sort方法用于对列表进行排序,修改原列表,不会返回一个已排序的列表副本

1 >>> result = [8,5,5,3,9]
2 >>> result.sort()
3 >>> result
4 [3, 5, 5, 8, 9]
如果我们想要返回一个已排序的列表副本,而不影响原来的列表呢,一种方法,我们可以先赋值原来列表(可以用分片赋值复制),然后
在复制的列表上做sort操作,另一种方法,就是使用sorted函数,它会返回已排序的列表副本:
1 >>> result = [8,5,5,3,9]
2 >>> result2 = sorted(result)
3 >>> result
4 [8, 5, 5, 3, 9]
5 >>> result2
6 [3, 5, 5, 8, 9]
关于自定义的比较方法,像javascript做sort可以传入compare函数,java可以传入 Comparable <T>实例,Python也类似,留待后续了~(@^_^@)~。

转载于:https://www.cnblogs.com/brzone/p/3546032.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值