自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Python列表的11個(gè)方法全解

開發(fā) 后端
列表是Python里面非常重要的數(shù)據(jù)類型,其中的方法總共有11個(gè),數(shù)量掌握這些方法,對(duì)數(shù)據(jù)的處理效率會(huì)大大提高,現(xiàn)在分享給大家。

列表是Python里面非常重要的數(shù)據(jù)類型,其中的方法總共有11個(gè),數(shù)量掌握這些方法,對(duì)數(shù)據(jù)的處理效率會(huì)大大提高,現(xiàn)在分享給大家。

  1. print(dir(list()))#查看列表的方法 
  2. [ ..., 'append', 'clear', 'copy', 'count', 'extend', 'index', 
  3.  'insert', 'pop', 'remove', 'reverse', 'sort'] 

[[349376]]

1. append()方法

描述:append() 方法在列表ls最后(末尾)添加一個(gè)元素object

語法:ls.append(object) object為要添加的元素。

參數(shù):object可以添加 列表,字典,元組,集合,字符串等。

  1.  #append()函數(shù)的操作對(duì)象是原列表。ls = [1,2,3,4,5,6] 
  2. ls.append(12)#添加元素 
  3. print(ls) 
  4. [1, 2, 3, 4, 5, 6, 12] 
  5. ls.append([1,"a"])  #添加列表 
  6. print(ls) 
  7. [1, 2, 3, 4, 5, 6, 12, [1, 'a']] 
  8.  
  9.  
  10. ls.append({2:"a",3:"hj"}) #添加字典 
  11. print(ls) 
  12. [1, 2, 3, 4, 5, 6, 12, [1, 'a'], {2: 'a', 3: 'hj'}] 
  13.  
  14.  
  15. ls.append((1,"k",3)) #添加元組 
  16. print(ls) 
  17. [1, 2, 3, 4, 5, 6, 12, [1, 'a'], {2: 'a', 3: 'hj'}, (1, 'k', 3)] 
  18.  
  19.  
  20. ls.append({"1","2","h"}) #添加集合 
  21. print(ls) 
  22. [1, 2, 3, 4, 5, 6, 12, [1, 'a'], {2: 'a', 3: 'hj'}, (1, 'k', 3), {'2', 'h', '1'}] 
  23.  
  24.  
  25. ls.append("123abc") #添加字符串 
  26. print(ls) 
  27. [1, 2, 3, 4, 5, 6, 12, [1, 'a'], {2: 'a', 3: 'hj'}, (1, 'k', 3), {'2', 'h', '1'}, '123ab 
  28.   

2. clear()方法

描述:刪除列表ls中的所有元素。

語法: ls.clear()

  1. ls = [1,2,3,"4",5,"a"] 
  2. ls.clear() 
  3. print(ls) 
  4. [] 

3. copy()方法

描述:生成一個(gè)新列表,復(fù)制ls中的所有元素。

語法: ls.copy() -> list 返回一個(gè)列表

  1. ls = [1,2,3,[4,5,6]] 
  2. lt = ls.copy() #lt復(fù)制ls中的所有元素 
  3. ls.clear() #刪除ls所有元素,lt中的元素沒有被刪除。 
  4. lk = ls #這不是復(fù)制,而是給列表ls新關(guān)聯(lián)一個(gè)引用,即增加一個(gè)別名,ls和lt指向同一個(gè)內(nèi)存地址。 
  5. print(id(ls),id(lk)) 
  6. print(lt) 
  7. print(ls) 

4. count()方法

描述:統(tǒng)計(jì)列表ls中value元素出現(xiàn)的次數(shù)

語法:ls.count(value) -> integer 返回一個(gè)整數(shù)

參數(shù):value--要統(tǒng)計(jì)的value元素。

  1. ls = [1,2,3,5,4,5,5,5,5,"python"] 
  2. ls.count(5) #統(tǒng)計(jì)列表ls中 5 出現(xiàn)的次數(shù) 
  3.  
  4. ls.count(0)#列表ls中無0元素 
  5.  
  6. ls.count("python") #統(tǒng)計(jì)列表ls中 "python" 出現(xiàn)的次數(shù)。 

5. extend()方法

描述:在列表ls末尾添加一個(gè)列表iterable。

語法:ls.extend(iterable) -> None 無返回值

參數(shù):iterable -- 要添加的列表??梢允钦麄€(gè)列表iterable,也可以是列表iterable的一部分。

注意:extend() 和 append() 的不同之處在于:extend() 不會(huì)把列表或者元祖視為一個(gè)整體,而是把它們包含的元素逐個(gè)添加到列表中

  1. ls = [1,2,"a",[4,5,"a"]] 
  2. lt = [1,"abc","b",[1,2]] 
  3. ls.extend(lt) #返回值為空,將列表lt的元素添加到列表ls末尾。 
  4. print(ls.extend(lt)) 
  5. None 
  6. print(ls) 
  7. [1, 2, 'a', [4, 5, 'a'], 1, 'abc', 'b', [1, 2], 1, 'abc', 'b', [1, 2]] 
  8.  
  9.  
  10. print(lt) #列表lt元素不變 
  11. [1, 'abc', 'b', [1, 2]] 

6. index()方法

描述:列表ls中第一次出現(xiàn)元素value的位置。

語法: ls.index(value, start, stop) -> integer 返回一個(gè)整數(shù)

參數(shù):

  • value —— 要查找的元素。
  • star —— 索引的起始位置。
  • stop —— 索引的結(jié)束位置。
  1. ls = [1,2,3,"a",3,5,"a",5,[1,7,"b"]] 
  2. ls.index("a") #返回列表ls中"a"第一次出現(xiàn)的位置。 
  3.  
  4. ls.index("a",4) #索引的起始位置為下標(biāo)為4的元素,索引范圍為 3, 5, 'a', 5, [1, 7, 'b' 
  5.           
  6. ls.index("a",4,8) #索引的起始位置為下標(biāo)為4的元素,結(jié)束位置為下標(biāo)為7的元素。索引范圍 3, 5, 'a', 5 

7. insert()方法

描述:在列表第index位置,添加元素object。

語法:ls.insert(index, object)

  • index —— 元素object插入列表ls的位置。
  • objece —— 將要添加的元素。可以是列表,元組,字典,集合,字符串等。
  1. ls = [1,2,"a",["a",5,8]] 
  2. ls.insert(3,"b")#在列表ls下標(biāo)為3的位置插入元素 "b" 
  3. print(ls) 
  4. [1, 2, 'a', 'b', 'b', ['a', 5, 8]] 
  5.  
  6. ls.insert(3,1)  #在列表ls下標(biāo)為3的位置插入元素 1 
  7. print(ls) 
  8. [1, 2, 'a', 1, 'b', 'b', ['a', 5, 8]] 
  9.  
  10. ls.insert(1,['a', 5, 8]) #在列表ls的內(nèi)嵌套列表["a",5,8] 
  11. print(ls) 
  12. [1, ['a', 5, 8], 2, 'a', 1, 'b', 'b', ['a', 5, 8]] 
  13.  
  14. ls = [1,2,3] 
  15. ls.insert(0,[1,2,3]) #插入列表 
  16. ls.insert(0,(1,2,3)) #插入元組 
  17. ls.insert(0,{1:"a",2:"b"}) #插入字典 
  18. ls.insert(0,{1,2,3}) #插入集合 
  19. print(ls) 
  20. [{1, 2, 3}, {1: 'a', 2: 'b'}, (1, 2, 3), [1, 2, 3], 1, 2 
  21.   

8. pop()方法

描述:將列表ls中第index項(xiàng)元素取出,并從列表ls中刪除該元素。若果省略index,則默認(rèn)刪除列表最后(末尾)一個(gè)元素,并返回該元素。

語法: ls.pop(index) -> item 返回刪除的項(xiàng)

參數(shù): index -- 要取出并刪除的元素下標(biāo)的序數(shù)。

  1. ls = [1,2,"a","y",[1,2,3],"b"] 
  2. ls.pop(0)#取出下標(biāo)為0的元素,并從列表ls中刪除。 
  3. print(ls) 
  4. [2, 'a', 'y', [1, 2, 3], 'b'] 
  5.  
  6.  
  7. ls.pop() #默認(rèn)取出列表ls最后一個(gè)元素,并刪除。 
  8. 'b' 
  9. print(ls) 
  10. [2, 'a', 'y', [1, 2, 3] 

9. remove()方法

描述:將列表ls中出現(xiàn)的第一個(gè)元素value刪除。

語法:ls.remove(value) -> None 返回值為空

參數(shù):value -- 要?jiǎng)h除的元素。

  1. ls1 = [1,2,"a",3,1,1,55,"a,1"] 
  2. ls2 = [1,2,"a",3,1,1,55,"a,1"] 
  3. ls1.remove(1) #刪除ls1中第一次出現(xiàn)的元素 1 
  4. ls2.remove("a") ##刪除ls2中第一次出現(xiàn)的元素 "a" 
  5. print(ls1.remove(1)) #返回值為空 
  6. print(ls1) 
  7. print(ls2) 

10. reverse()方法

描述:將列表ls中的元素反轉(zhuǎn)。

語法:ls.reverse()

  1. ls1 = [1,2,3,4,5,6,7,8,9] 
  2. ls1.reverse() #將列表ls1反轉(zhuǎn)輸出 
  3. print(ls1) 
  4. [9, 8, 7, 6, 5, 4, 3, 2, 1] 
  5.  
  6. ls2 = [2,5,8,9,4,1,2,6,2,1,3] 
  7. ls2.sort(reverse=True) #ls2.sort()默認(rèn)將列表ls2按從小到大的序數(shù)排列。reverse=True 使排序后的列表反轉(zhuǎn),reverse=False 則不反轉(zhuǎn) 
  8. print(ls2) 
  9. [9, 8, 6, 5, 4, 3, 2, 2, 2, 1, 1] 

11. sort() 方法

描述:將原列表ls中的元素進(jìn)行排序,意味著改變?cè)瓉淼牧斜?,而不是返回一個(gè)列表

語法:ls.sort([key=None][,reverse=False])--無返回值,但是會(huì)對(duì)列表中的元素進(jìn)行排序。

參數(shù):

  • key-- 可選參數(shù), 如果指定了該參數(shù)會(huì)使用該參數(shù)的方法進(jìn)行排序。
  • reverse-- 可選參數(shù),是否反向排序,默認(rèn)為False。
  1. ls = [1,3,7,2,4,5,6] 
  2. ls.sort() 
  3. print(ls) 
  4. [1, 2, 3, 4, 5, 6, 7]#原來的列表發(fā)生了改變 
  5.  
  6. 當(dāng)用戶需要一個(gè)排列好的列表,同時(shí)又要保留原來的列表時(shí),怎么做 
  7. 錯(cuò)誤方法1: 
  8. ls = [1,3,7,2,4,5,6] 
  9. y = ls.sort() 
  10. print(y) 
  11. None 
  12. print(ls) 
  13.  
  14. #錯(cuò)誤方法2: 
  15. ls = [1,3,7,2,4,5,6] 
  16. y = ls 
  17. y.sort() 
  18.  
  19. print(ls) 
  20. [1, 2, 3, 4, 5, 6, 7] 
  21. print(y) 
  22. [1, 2, 3, 4, 5, 6, 7] 
  23.  
  24. 正確方法: 
  25. ls = [1,3,7,2,4,5,6] 
  26. y = ls[:] 
  27. y.sort() 
  28. print(ls) 
  29. [1, 3, 7, 2, 4, 5, 6]#舊的列表未改變 
  30. print(y) 
  31. [1, 2, 3, 4, 5, 6, 7]#新的列表改變 
  32.  
  33.  
  34. 另外一種獲取副本的方法,是用sorted() 函數(shù) 
  35. ls = [1,3,7,2,4,5,6] 
  36. y = sorted(ls) 
  37. print(y) 
  38. [1, 2, 3, 4, 5, 6, 7] 
  39. print(ls) 
  40. [1, 3, 7, 2, 4, 5, 6]#未發(fā)生改變 
  41.  
  42.  
  43. 降序的方法,現(xiàn)用sort 或者 sorted() 然后用reverse()進(jìn)行反轉(zhuǎn) 
  44. ls = [1,3,7,2,4,5,6] 
  45. y = sorted(ls) 
  46. y.reverse() 
  47. print(y) 
  48. [7, 6, 5, 4, 3, 2, 1] 
  49.  
  50.  
  51. 當(dāng)然,sort方法還有兩個(gè)參數(shù),key和reverse 
  52.  
  53.  
  54. ls = ['a22112x','aaaba','xxvvv','5aa','wodesddddssd'] 
  55.  
  56.  
  57. ls.sort(key=len
  58. print(ls) 
  59. ['5aa', 'aaaba', 'xxvvv', 'a22112x', 'wodesddddssd'] 
  60. ##按a的個(gè)數(shù)進(jìn)行排序 
  61. 定義一個(gè)計(jì)算'a'的個(gè)數(shù)的函數(shù) 
  62. ls = ['1a22112x','2aaaba','3xxvvv','4b5aa','5wodesddddssd'] 
  63. def a_fun(x): 
  64.     return str(x).count('a') 
  65.      
  66. ls.sort(key=a_fun
  67. print(ls) 
  68. ['3xxvvv', '5wodesddddssd', '1a22112x', '4b5aa', '2aaaba'] 
  69.  
  70. ls = [1,3,7,2,4,5,6] 
  71. ls.sort(reverse=True
  72. [7, 6, 5, 4, 3, 2, 1] 

 

責(zé)任編輯:趙寧寧 來源: AI入門學(xué)習(xí)
相關(guān)推薦

2022-12-13 07:55:00

Python地理編碼

2024-10-28 21:11:52

2009-09-23 17:36:26

Hibernate優(yōu)點(diǎn)

2009-11-13 11:32:33

路由器設(shè)置

2022-11-25 09:00:00

云計(jì)算云原生容器

2009-11-11 09:50:25

思科路由器口令恢復(fù)

2018-03-01 14:10:37

Kubernetes負(fù)載均衡容器

2010-01-04 09:39:39

Silverlight

2010-04-20 11:51:31

負(fù)載均衡

2010-07-28 22:20:10

RIP路由配置

2010-09-25 13:07:50

DHCP協(xié)議結(jié)構(gòu)

2010-07-13 13:59:04

ICMP協(xié)議

2011-03-30 10:07:02

Zabbix安裝

2009-12-18 14:19:01

無線擴(kuò)展通信技術(shù)特點(diǎn)

2010-07-13 14:44:11

SNMP服務(wù)設(shè)置

2010-07-14 16:21:31

Telnet服務(wù)配置

2009-11-10 16:03:44

2011-03-23 14:43:07

Nagios監(jiān)控

2022-01-20 09:00:00

架構(gòu)IT企業(yè)

2010-07-27 09:30:22

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)