当前位置:天才代写 > tutorial > Python教程 > Python操纵列表的常用要领总结

Python操纵列表的常用要领总结

2017-11-02 08:00 星期四 所属: Python教程 浏览:81

下面列出列表常用的要领操纵列表以及小例子:

1.  Append

在列表末端添加元素,需在列表末端添加元素,需要留意几个点:

 A. append中添加的参数是作为一个整体

  

>>> name = list("scott")

>>> name

['s', 'c', 'o', 't', 't']

>>> name.append(list(" tiger"))

>>> name

['s', 'c', 'o', 't', 't', [' ', 't', 'i', 'g', 'e', 'r']]

获得的值不是:['s', 'c', 'o', 't', 't', ' ', 't', 'i', 'g', 'e', 'r']

假如想要这种的追加方法,可以试试分片赋值(可能下面说到的extend要领):

>>> name = list("scott")

>>> name

['s', 'c', 'o', 't', 't']

>>> name[len(name):] = list(" tiger")      #从末端追加

>>> name

['s', 'c', 'o', 't', 't', ' ', 't', 'i', 'g', 'e', 'r']

B.append一次性只能添加一个元素

>>> name = list("scott")

>>> name

['s', 'c', 'o', 't', 't']

>>> name.append("A","B")        #添加多个元素即将报错

Traceback (most recent call last):

  File "", line 1, in ?

TypeError: append() takes exactly one argument (2 given)

>>> name.append("A")

>>> name

['s', 'c', 'o', 't', 't', 'A']

 

2. Count

     统计某个元素在列表中呈现的次数

>>> name = list("scott")

>>> name

['s', 'c', 'o', 't', 't']

>>> name.count('s')

>>> name.count("t")

>>> name.count("A")

>>> name.append(list("Python"))

>>> name

['s', 'c', 'o', 't', 't', ['P', 'y', 't', 'h', 'o', 'n']]

>>> name.count(['P', 'y', 't', 'h', 'o', 'n'])

 

3. Extend

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

>>> name = list("scott")

>>> name

['s', 'c', 'o', 't', 't']

>>> name.extend(list(" tiger"))

>>> name

['s', 'c', 'o', 't', 't', ' ', 't', 'i', 'g', 'e', 'r']

虽然,我们可以用分片赋值来实现:

>>> name = list("scott")

>>> name

['s', 'c', 'o', 't', 't']

>>> name[len(name):] = list(" tiger")

>>> name

['s', 'c', 'o', 't', 't', ' ', 't', 'i', 'g', 'e', 'r']

这时小同伴们会想到,我们可以直接用操纵符"+"嘛,还利便些:

>>> name = list("scott")

>>> pwd  = list(" tiger")

>>> name + pwd

['s', 'c', 'o', 't', 't', ' ', 't', 'i', 'g', 'e', 'r']

>>> name

['s', 'c', 'o', 't', 't']

从这三种方法操纵的输出,可以看出:

extend和分片赋值都是修改原列表,相对而言,extend可读性强些,而操纵符"+"是生成一个新的列表,不影响原列表,假如

我们需要生成新列表而不影响原列表,就可以用操纵符"+"。

 

4.Index

从列表中找出某个值第一个(留意是第一个)匹配项的索引位置

>>> name = list("scott")

>>> name

['s', 'c', 'o', 't', 't']

>>> name.index('t')    ##第一个字母t的索引位置是3

  

>>> name.index('a')

Traceback (most recent call last):

  File "", line 1, in ?

ValueError: list.index(x): x not in list

>>> 'a' in name

False

>>> 'a' not in name

True

从输出可以看出,index找的是第一个匹配项的索引位置,而假如查找的元素不在列表中,会报错(返回-1会不会好一点呢?),虽然假如想制止报

错,我们可以先用in操纵,判定某个元素是否在某个列表中,假如在的话,然后举办index操纵。

 

5. Insert

    用于将工具插入到列表中,俩个参数,第一个是索引位置,第二个插入的元素工具。

>>> name = list("scott")

>>> name

['s', 'c', 'o', 't', 't']

>>> name.insert(2,'tiger')     ##在索引为2的处所插入字符串tiger  

>>> name

['s', 'c', 'tiger', 'o', 't', 't']

我们也可以用分片赋值:

>>> name = list("scott")

>>> name

['s', 'c', 'o', 't', 't']

>>> name[2:2] = ['tiger']

>>> name

['s', 'c', 'tiger', 'o', 't', 't']

>>> name[2:2] = 'tiger'

>>> name

['s', 'c', 't', 'i', 'g', 'e', 'r', 'tiger', 'o', 't', 't']

这里需要留意的是,假如是插入一个元素,需要用[]括起来,否则,直接用字符串的话,是插入字符串的列表,在索引位置之后添加。

虽然,用insert的可读性比分片赋值强。

 

6. Pop

    移除列表中的一个元素(最后一个元素),并返回该元素的值

>>> name = list("scott")

>>> name

['s', 'c', 'o', 't', 't']

>>> name.pop()

't'

>>> name

['s', 'c', 'o', 't']

>>> name.append("t")

>>> name

['s', 'c', 'o', 't', 't']

分片赋值模仿pop:

>>> name = list("scott")

>>> name

['s', 'c', 'o', 't', 't']

>>> name[len(name)-1:] = []

>>> name

['s', 'c', 'o', 't']

这上面用pop和append模仿了栈的先进先出LIFO。

 

7. Remove

#p#分页标题#e#

   移除列表中某个值的第一匹配项: 假如有俩个相等的元素,就只是移除匹配的一个元素,假如某元素不存在某列表中,便会报错,并且一次性只能

   移除一个元素。

>>> name = list("scott")

>>> name

['s', 'c', 'o', 't', 't']

>>> name.remove("t")    #去掉第一个t

>>> name

['s', 'c', 'o', 't']

>>> name.remove("A")    #不存在会报错

Traceback (most recent call last):

  File "", line 1, in ?

ValueError: list.remove(x): x not in list

>>> "A" not in name

True

>>> name.remove("s","c")  #一次只能移除一个元素

Traceback (most recent call last):

  File "", line 1, in ?

TypeError: remove() takes exactly one argument (2 given)

 

8.Revense

   将列表中的元素反向

>>> name = list("scott")

>>> name

['s', 'c', 'o', 't', 't']

>>> name.reverse()

>>> name

['t', 't', 'o', 'c', 's']

 

9. Sort & Sorted

    sort要领用于对列表举办排序,修改原列表,不会返回一个已排序的列表副本

>>> result = [8,5,5,3,9]

>>> result.sort()

>>> result

[3, 5, 5, 8, 9]

假如我们想要返回一个已排序的列表副本,而不影响本来的列表呢,一种要领,我们可以先赋值本来列表(可以用分片赋值复制),然后

在复制的列表上做sort操纵,另一种要领,就是利用sorted函数,它会返回已排序的列表副本:

>>> result = [8,5,5,3,9]

>>> result2 = sorted(result)

>>> result

[8, 5, 5, 3, 9]

>>> result2

[3, 5, 5, 8, 9]

 

    关键字:


天才代写-代写联系方式