一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - Python實現list反轉實例匯總

Python實現list反轉實例匯總

2020-05-12 09:51腳本之家 Python

這篇文章主要介紹了Python實現list反轉的方法,實例總結了關于list的各種較為常見的操作技巧,需要的朋友可以參考下

本文實例總結了Python實現list反轉的方法。分享給大家供大家參考。具體實現方法如下:

下面有幾個不同實現的函數

復制代碼 代碼如下:
import math
 
def resv(li):
    new = []
    if li:
        cnt = len(li)
        for i in range(cnt):
            new.append(li[cnt-i-1])
    return new
 
def resv2(li):
    li.reverse()
    return li
 
def resv3(li):
    hcnt = int(math.floor(len(li)/2))
    tmp = 0
    for i in range(hcnt):
        tmp = li[i]
        li[i] = li[-(i+1)]
        li[-(i+1)] = tmp
    return li
 
li = [1, 2, 3, 4, 5]
 
print resv(li)


ps: resv2() 方法會改變原來list的排序,其它則不會
一些關于list基礎用法
1.定義list

復制代碼 代碼如下:
    >>> li = ["a", "b", "mpilgrim", "z", "example"]
    >>> li
    ['a', 'b', 'mpilgrim', 'z', 'example']
    >>> li[0]                                     
    'a'
    >>> li[4]                                     
    'example'


 
2.負的list 索引

復制代碼 代碼如下:
    >>> li
    ['a', 'b', 'mpilgrim', 'z', 'example']
    >>> li[-1]
    'example'
    >>> li[-3]
    'mpilgrim'
    >>> li
    ['a', 'b', 'mpilgrim', 'z', 'example']
    >>> li[1:3]
    ['b', 'mpilgrim']
    >>> li[1:-1]
    ['b', 'mpilgrim', 'z']
    >>> li[0:3]
    ['a', 'b', 'mpilgrim']


 
3.向 list 中增加元素

復制代碼 代碼如下:
    >>> li
    ['a', 'b', 'mpilgrim', 'z', 'example']
    >>> li.append("new")             
    >>> li
    ['a', 'b', 'mpilgrim', 'z', 'example', 'new']
    >>> li.insert(2, "new")          
    >>> li
    ['a', 'b', 'new', 'mpilgrim', 'z', 'example', 'new']
    >>> li.extend(["two", "elements"])
    >>> li
    ['a', 'b', 'new', 'mpilgrim', 'z', 'example', 'new', 'two', 'elements']


 
4.搜索 list

復制代碼 代碼如下:
    >>> li
    ['a', 'b', 'new', 'mpilgrim', 'z', 'example', 'new', 'two', 'elements']
    >>> li.index("example")
    5
    >>> li.index("new")   
    2
    >>> li.index("c")     
    Traceback (innermost last):
      File "<interactive input>", line 1, in ?
    ValueError: list.index(x): x not in list
    >>> "c" in li         
    False


 
5.從 list 中刪除元素

復制代碼 代碼如下:
    >>> li
    ['a', 'b', 'new', 'mpilgrim', 'z', 'example', 'new', 'two', 'elements']
    >>> li.remove("z") 
    >>> li
    ['a', 'b', 'new', 'mpilgrim', 'example', 'new', 'two', 'elements']
    >>> li.remove("new")
    >>> li
    ['a', 'b', 'mpilgrim', 'example', 'new', 'two', 'elements']
    >>> li.remove("c") 
    Traceback (innermost last):
      File "<interactive input>", line 1, in ?
    ValueError: list.remove(x): x not in list
    >>> li.pop()       
    'elements'
    >>> li
    ['a', 'b', 'mpilgrim', 'example', 'new', 'two']


remove 從 list 中刪除一個值的首次出現。
remove 僅僅 刪除一個值的首次出現。 在這里, 'new' 在 list 中出現了兩次, 但 li.remove("new") 只刪除了 'new' 的首次出現。
如果在 list 中沒有找到值, Python 會引發一個異常來響應 index 方法。
pop 會做兩件事: 刪除 list 的最后一個元素, 然后返回刪除元素的值。

 

6.list 運算符

復制代碼 代碼如下:
    >>> li = ['a', 'b', 'mpilgrim']
    >>> li = li + ['example', 'new']
    >>> li
    ['a', 'b', 'mpilgrim', 'example', 'new']
    >>> li += ['two']              
    >>> li
    ['a', 'b', 'mpilgrim', 'example', 'new', 'two']
    >>> li = [1, 2] * 3            
    >>> li
    [1, 2, 1, 2, 1, 2]


 
7.使用join鏈接list成為字符串

復制代碼 代碼如下:
    >>> params = {"server":"mpilgrim", "database":"master", "uid":"sa", "pwd":"secret"}
    >>> ["%s=%s" % (k, v) for k, v in params.items()]
    ['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret']
    >>> ";".join(["%s=%s" % (k, v) for k, v in params.items()])
    'server=mpilgrim;uid=sa;database=master;pwd=secret'


join 只能用于元素是字符串的 list; 它不進行任何的類型強制轉換。連接一個存在一個或多個非字符串元素的 list 將引發一個異常。

 

8.分割字符串

復制代碼 代碼如下:
    >>> li = ['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret']
    >>> s = ";".join(li)
    >>> s
    'server=mpilgrim;uid=sa;database=master;pwd=secret'
    >>> s.split(";")  
    ['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret']
    >>> s.split(";", 1)
    ['server=mpilgrim', 'uid=sa;database=master;pwd=secret']


split 與 join 正好相反, 它將一個字符串分割成多元素 list。
注意, 分隔符 (“;”) 被完全去掉了, 它沒有在返回的 list 中的任意元素中出現。
split 接受一個可選的第二個參數, 它是要分割的次數。

 

9.list的映射解析

復制代碼 代碼如下:
    >>> li = [1, 9, 8, 4]
    >>> [elem*2 for elem in li]    
    [2, 18, 16, 8]
    >>> li                         
    [1, 9, 8, 4]
    >>> li = [elem*2 for elem in li]
    >>> li
    [2, 18, 16, 8]


 
10.dictionary中的解析

復制代碼 代碼如下:
    >>> params = {"server":"mpilgrim", "database":"master", "uid":"sa", "pwd":"secret"}
    >>> params.keys() 
    ['server', 'uid', 'database', 'pwd']
    >>> params.values()
    ['mpilgrim', 'sa', 'master', 'secret']
    >>> params.items()
    [('server', 'mpilgrim'), ('uid', 'sa'), ('database', 'master'), ('pwd', 'secret')]
    >>> [k for k, v in params.items()]              
    ['server', 'uid', 'database', 'pwd']
    >>> [v for k, v in params.items()]              
    ['mpilgrim', 'sa', 'master', 'secret']
    >>> ["%s=%s" % (k, v) for k, v in params.items()]
    ['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret']


 
11.列表過濾

復制代碼 代碼如下:
    >>> li = ["a", "mpilgrim", "foo", "b", "c", "b", "d", "d"]
    >>> [elem for elem in li if len(elem) > 1]     
    ['mpilgrim', 'foo']
    >>> [elem for elem in li if elem != "b"]       
    ['a', 'mpilgrim', 'foo', 'c', 'd', 'd']
    >>> [elem for elem in li if li.count(elem) == 1]
    ['a', 'mpilgrim', 'foo', 'c']

 

希望本文所述對大家的Python程序設計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 小sao货水好多真紧h的视频 | 成人猫咪maomiav永久网址 | 亚洲性久久久影院 | 成成人看片在线 | 小便japanesewctv| 免费一级毛片在线播放 | 亚洲国产成人精品不卡青青草原 | 日韩福利一区 | 日本老妇成熟 | 跪在老师脚下吃丝袜脚 | 日本一级不卡一二三区免费 | 妹妹骑上来蹭着蹭着就射了 | 日本高清在线看免费观看 | 嫩草成人影院 | 精品国语国产在线对白 | 午夜免费小视频 | 精品国产福利片在线观看 | 欧美最猛性xxxxx动态图 | 9热在线精品视频观看 | 情侣奴伺候女王第2部分小说 | 免费抽搐一进一出印度 | 亚洲网红精品大秀在线观看 | 久久偷拍人 | 国产福利一区二区三区四区 | 久久精品久久久 | 天天插在线视频 | 欧美日韩国产亚洲人成 | 免费二级毛片免费完整视频 | 肉宠文很肉到处做1v1 | 日本狠狠操| 免费在线观看日韩 | 国产精品视频第一区二区三区 | 成人免费在线视频网 | 日本嫩小xxxxhd| 极品虎白女在线观看一线天 | 五月天精品视频在线观看 | 秋霞一级毛片 | 俺去啦最新地址 | 国产日韩高清一区二区三区 | xxx黑人又大粗又长 xxxx性欧美极品另类 | 精品亚洲一区二区三区在线播放 |