Python基礎(chǔ)——Slice、列表生成器、Iteration、Generator

切片 Slice

獲取指定范圍的list或tuple list[m:n]從位置m開始,截止到位置n(不包括n)

L = ['luseike', 'lemon', 'sara', 'neal', 'mike']

print(L[0:3])       # ['luseike', 'lemon', 'sara']
print(L[:4])        # ['luseike', 'lemon', 'sara', 'neal']

print(L[-1])        # mike
print(L[-3:-1])     # ['sara', 'neal'] 從倒數(shù)第3個(gè)截到倒數(shù)第1個(gè)

記?。旱箶?shù)第一個(gè)元素的索引是-1

tuple也是一種list,可以用slice操作,只是操作的結(jié)果仍然是不可變的tuple

Iteration

通過for循環(huán)來遍歷的操作稱之為迭代,Python中所有可迭代對(duì)象都可以用for循環(huán)


d = {'a':1, 'b':2, 'c':3}
for key in d:
    print(key)

for value in d.values():
    print(value)

for k, v in d.items():
    print(k, v)

from collections import Iterable
print(isinstance('abc', Iterable))
print(isinstance(123, Iterable))

通過collections模塊的Iterable類型,判斷一個(gè)對(duì)象是否是可迭代對(duì)象

Python內(nèi)置的enumerate函數(shù),可以把一個(gè)list變成索引-元素對(duì)

在for循環(huán)中同時(shí)迭代索引和元素本身

for i, value in enumerate(['a', 'b', 'c']):
    print(i, value)

列表生成式

1、 普通列表

list(range(1, 11))      # 生成1-10的list
list(range(1, 11, 2))   # [1, 3, 5, 7, 9] 跳步數(shù)為2

2、表達(dá)式內(nèi)遍歷操作生成列表

print([x * x for x in range(1, 11) if x % 2 == 0])
# [4, 16, 36, 64, 100]

寫列表生成式時(shí),把要生成的元素放到前面,后面跟for循環(huán)

列表生成式也可以使用兩個(gè)變量來生成list

friends = {'a':'lemon', 'b':'dowan', 'c':'lorence'}
print([k + ' = ' + v for k, v in friends.items()])
# ['a = lemon', 'b = dowan', 'c = lorence']

生成器 Generator

創(chuàng)建generator,第一種方法:把一個(gè)列表生成式的[]改成()

L = [x * x for x in range(10)]
print(L)
# [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
g = (x * x for x in range(10))
print(g)
# <generator object <genexpr> at 0x102c17ca8>

可以通過next()函數(shù)獲得generator的下一個(gè)返回值 next(g)

generator保存的是算法,每次調(diào)用next(g)就計(jì)算出g的下一個(gè)元素的值,直到計(jì)算到最后一個(gè)元素,沒有更多的元素時(shí),拋出StopIteration錯(cuò)誤。因?yàn)間enerator也是可迭代對(duì)象,在for循環(huán)中獲得每次計(jì)算的結(jié)果

創(chuàng)建generator,第二種方法:如果一個(gè)函數(shù)定義中包含yield關(guān)鍵字,那么這個(gè)函數(shù)就是一個(gè)generator

def fib(max):
    n = 0
    a = 0
    b = 1
    while n < max:
        print(b)
        a, b = b, (a + b)
        n = n + 1
    return 'done'

def fib(max):
    n = 0
    a = 0
    b = 1
    while n < max:
        yield b
        a, b = b, (a + b)
        n = n + 1
    return 'done'

generator和函數(shù)的執(zhí)行流程不一樣

  • 函數(shù)是順序執(zhí)行,遇到return或者最后一行函數(shù)語句就返回
  • generator的函數(shù),每次調(diào)用next()的時(shí)候執(zhí)行,遇到y(tǒng)ield語句返回,再次執(zhí)行時(shí)從上次返回的yield語句處繼續(xù)執(zhí)行
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容