欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python操作列表的常用方法分享

 更新時(shí)間:2014年02月13日 16:40:15   作者:  
這篇文章主要介紹了Python操作列表的常用方法,需要的朋友可以參考下

下面列出列表常用的方法操作列表以及小例子:

1.  Append
     在列表末尾添加元素,需在列表末尾添加元素,需要注意幾個(gè)點(diǎn):
     A. append中添加的參數(shù)是作為一個(gè)整體

復(fù)制代碼 代碼如下:

 >>> 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']
如果想要這種的追加方式,可以試試分片賦值(或者下面說(shuō)到的extend方法):

復(fù)制代碼 代碼如下:

 >>> 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一次性只能添加一個(gè)元素

復(fù)制代碼 代碼如下:

>>> name = list("scott")
>>> name
['s', 'c', 'o', 't', 't']
>>> name.append("A","B")        #添加多個(gè)元素即將報(bào)錯(cuò)
Traceback (most recent call last):
  File "<stdin>", line 1, in ?
TypeError: append() takes exactly one argument (2 given)
>>> name.append("A")
>>> name
['s', 'c', 'o', 't', 't', 'A']

2. Count

統(tǒng)計(jì)某個(gè)元素在列表中出現(xiàn)的次數(shù)

復(fù)制代碼 代碼如下:

>>> name = list("scott")
>>> name
['s', 'c', 'o', 't', 't']
>>> name.count('s')
1
>>> name.count("t")
2
>>> name.count("A")
0
>>> name.append(list("Python"))
>>> name
['s', 'c', 'o', 't', 't', ['P', 'y', 't', 'h', 'o', 'n']]
>>> name.count(['P', 'y', 't', 'h', 'o', 'n'])
1

3. Extend

   在原列表追加另一個(gè)序列的中的多個(gè)值

復(fù)制代碼 代碼如下:

 >>> name = list("scott")
 >>> name
 ['s', 'c', 'o', 't', 't']
 >>> name.extend(list(" tiger"))
 >>> name
 ['s', 'c', 'o', 't', 't', ' ', 't', 'i', 'g', 'e', 'r']

當(dāng)然,我們可以用分片賦值來(lái)實(shí)現(xiàn):

復(fù)制代碼 代碼如下:

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

這時(shí)小伙伴們會(huì)想到,我們可以直接用操作符"+"嘛,還方便些:

復(fù)制代碼 代碼如下:

 >>> 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和分片賦值都是修改原列表,相對(duì)而言,extend可讀性強(qiáng)些,而操作符"+"是生成一個(gè)新的列表,不影響原列表,如果
我們需要生成新列表而不影響原列表,就可以用操作符"+"。

4.Index
從列表中找出某個(gè)值第一個(gè)(注意是第一個(gè))匹配項(xiàng)的索引位置

復(fù)制代碼 代碼如下:

>>> name = list("scott")
>>> name
['s', 'c', 'o', 't', 't']
>>> name.index('t')    ##第一個(gè)字母t的索引位置是3
3  
>>> name.index('a')
Traceback (most recent call last):
  File "<stdin>", line 1, in ?
ValueError: list.index(x): x not in list
>>> 'a' in name
False
>>> 'a' not in name
True

從輸出可以看出,index找的是第一個(gè)匹配項(xiàng)的索引位置,而如果查找的元素不在列表中,會(huì)報(bào)錯(cuò)(返回-1會(huì)不會(huì)好一點(diǎn)呢?),當(dāng)然如果想避免報(bào)
錯(cuò),我們可以先用in操作,判斷某個(gè)元素是否在某個(gè)列表中,如果在的話,然后進(jìn)行index操作。

5. Insert
    用于將對(duì)象插入到列表中,倆個(gè)參數(shù),第一個(gè)是索引位置,第二個(gè)插入的元素對(duì)象。

復(fù)制代碼 代碼如下:

 >>> name = list("scott")
 >>> name
 ['s', 'c', 'o', 't', 't']
 >>> name.insert(2,'tiger')     ##在索引為2的地方插入字符串tiger 
 >>> name
 ['s', 'c', 'tiger', 'o', 't', 't']

我們也可以用分片賦值:

復(fù)制代碼 代碼如下:

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

這里需要注意的是,如果是插入一個(gè)元素,需要用[]括起來(lái),不然,直接用字符串的話,是插入字符串的列表,在索引位置之后添加。
當(dāng)然,用insert的可讀性比分片賦值強(qiáng)。

6. Pop
    移除列表中的一個(gè)元素(最后一個(gè)元素),并返回該元素的值

復(fù)制代碼 代碼如下:

>>> 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:
復(fù)制代碼 代碼如下:

 >>> name = list("scott")
 >>> name
 ['s', 'c', 'o', 't', 't']
 >>> name[len(name)-1:] = []
 >>> name
 ['s', 'c', 'o', 't']

這上面用pop和append模擬了棧的先進(jìn)先出LIFO。

7. Remove
   移除列表中某個(gè)值的第一匹配項(xiàng): 如果有倆個(gè)相等的元素,就只是移除匹配的一個(gè)元素,如果某元素不存在某列表中,便會(huì)報(bào)錯(cuò),而且一次性只能
   移除一個(gè)元素。

復(fù)制代碼 代碼如下:

>>> name = list("scott")
>>> name
['s', 'c', 'o', 't', 't']
>>> name.remove("t")    #去掉第一個(gè)t
>>> name
['s', 'c', 'o', 't']
>>> name.remove("A")    #不存在會(huì)報(bào)錯(cuò)
Traceback (most recent call last):
  File "<stdin>", line 1, in ?
ValueError: list.remove(x): x not in list
>>> "A" not in name
True
>>> name.remove("s","c")  #一次只能移除一個(gè)元素
Traceback (most recent call last):
  File "<stdin>", line 1, in ?
TypeError: remove() takes exactly one argument (2 given)

8.Revense

   將列表中的元素反向

復(fù)制代碼 代碼如下:

 >>> name = list("scott")
 >>> name
 ['s', 'c', 'o', 't', 't']
 >>> name.reverse()
 >>> name
 ['t', 't', 'o', 'c', 's']

9. Sort & Sorted

    sort方法用于對(duì)列表進(jìn)行排序,修改原列表,不會(huì)返回一個(gè)已排序的列表副本

復(fù)制代碼 代碼如下:

 >>> result = [8,5,5,3,9]
 >>> result.sort()
 >>> result
 [3, 5, 5, 8, 9]

如果我們想要返回一個(gè)已排序的列表副本,而不影響原來(lái)的列表呢,一種方法,我們可以先賦值原來(lái)列表(可以用分片賦值復(fù)制),然后
在復(fù)制的列表上做sort操作,另一種方法,就是使用sorted函數(shù),它會(huì)返回已排序的列表副本:

復(fù)制代碼 代碼如下:

 >>> result = [8,5,5,3,9]
 >>> result2 = sorted(result)
 >>> result
 [8, 5, 5, 3, 9]
 >>> result2
 [3, 5, 5, 8, 9]

關(guān)于自定義的比較方法,像javascript做sort可以傳入compare函數(shù),java可以傳入Comparable<T>實(shí)例,Python也類(lèi)似,留待后續(xù)了~(@^_^@)~。

相關(guān)文章

  • Python中flatten( )函數(shù)及函數(shù)用法詳解

    Python中flatten( )函數(shù)及函數(shù)用法詳解

    flatten是numpy.ndarray.flatten的一個(gè)函數(shù),即返回一個(gè)一維數(shù)組。這篇文章主要介紹了Python中flatten( )函數(shù),需要的朋友可以參考下
    2018-11-11
  • python迭代器與生成器詳解

    python迭代器與生成器詳解

    迭代器和生成器都是Python中特有的概念,迭代器可以看作是一個(gè)特殊的對(duì)象,每次調(diào)用該對(duì)象時(shí)會(huì)返回自身的下一個(gè)元素,從實(shí)現(xiàn)上來(lái)看,一個(gè)可迭代的對(duì)象必須是定義了__iter__()方法的對(duì)象,而一個(gè)迭代器必須是定義了__iter__()方法和next()方法的對(duì)象。
    2016-03-03
  • python中的字典使用分享

    python中的字典使用分享

    Python 中的字典是Python中一個(gè)鍵值映射的數(shù)據(jù)結(jié)構(gòu),下面介紹一下如何操作字典,希望大家能夠喜歡
    2016-07-07
  • Pytorch損失函數(shù)torch.nn.NLLLoss()的使用

    Pytorch損失函數(shù)torch.nn.NLLLoss()的使用

    這篇文章主要介紹了Pytorch損失函數(shù)torch.nn.NLLLoss()的使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • Python著名游戲?qū)崙?zhàn)之方塊連接 我的世界

    Python著名游戲?qū)崙?zhàn)之方塊連接 我的世界

    讀萬(wàn)卷書(shū)不如行萬(wàn)里路,學(xué)的扎不扎實(shí)要通過(guò)實(shí)戰(zhàn)才能看出來(lái),本篇文章手把手帶你模仿著名游戲——我的世界,大家可以在過(guò)程中查缺補(bǔ)漏,看看自己掌握程度怎么樣
    2021-10-10
  • python爬蟲(chóng)遇到403錯(cuò)誤的問(wèn)題及解決

    python爬蟲(chóng)遇到403錯(cuò)誤的問(wèn)題及解決

    這篇文章主要介紹了python爬蟲(chóng)遇到403錯(cuò)誤的問(wèn)題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-02-02
  • Python爬蟲(chóng)信息輸入及頁(yè)面的切換方法

    Python爬蟲(chóng)信息輸入及頁(yè)面的切換方法

    今天小編就為大家分享一篇Python爬蟲(chóng)信息輸入及頁(yè)面的切換方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-05-05
  • 詳解python3中socket套接字的編碼問(wèn)題解決

    詳解python3中socket套接字的編碼問(wèn)題解決

    本篇文章主要介紹了詳解python3中socket套接字的編碼問(wèn)題解決,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • python中join與os.path.join()函數(shù)實(shí)例詳解

    python中join與os.path.join()函數(shù)實(shí)例詳解

    os.path.join()函數(shù)用于路徑拼接文件路徑,下面這篇文章主要給大家介紹了關(guān)于python中join與os.path.join()函數(shù)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-03-03
  • matlab xlabel位置的設(shè)置方式

    matlab xlabel位置的設(shè)置方式

    這篇文章主要介紹了matlab xlabel位置的設(shè)置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-05-05

最新評(píng)論