day-11總結(jié)

函數(shù)的變量

1.函數(shù)調(diào)用表達(dá)式

'''
函數(shù)調(diào)用表達(dá)式 - 調(diào)用函數(shù)的語(yǔ)句
普通值能做的事情函數(shù)調(diào)用表達(dá)式都可以做
'''

2.函數(shù)作為變量

'''
!9押取辉川!python中聲明函數(shù)本質(zhì)就是聲明一個(gè)類型是function的變量,函數(shù)名就是變量名

變量能做的事情蒲讯,函數(shù)都可以做
'''
聲明一個(gè)類型是function的變量,func4是變量

def func4(x):
    print(x)
print('=========')
a = 10
print(type(a), type(func4))

1)一個(gè)變量可以給另一個(gè)變量賦值

b = a
print(b+20)

c = func4
c(100)
print(c(100))    #None

2)給變量重新賦值

a = 'abc'
print(a)

func4 = 321
print(func4*2)

3)變量作為容器的元素

a = 10
list1 = [a, 10]
print(list1[0]/2)   # 5

def func4(x):
    print('函數(shù):', x)

4)變量可以作為函數(shù)的參數(shù)
'''
一個(gè)函數(shù)可以作為另一個(gè)函數(shù)的參數(shù)粹湃,
如果一個(gè)函數(shù)的參數(shù)也是函數(shù)恐仑,那么這種函數(shù)叫實(shí)參高階函數(shù)

'''
def func6(x):
x() # x()是調(diào)用函數(shù)的語(yǔ)句, 所以參數(shù)x的類型必須是函數(shù)

print('=========+++++++++++')

實(shí)參高階函數(shù):列表.sort()为鳄、sorted()裳仆、max()、min()
nums = [1, 78, 9, 78, 67, 100]
print(nums.sort())
print(nums)
print('++++++++++++++========')
nums = (1, 78, 9, 78, 67, 100)
print(sorted(nums))
print(nums)

sort和sorted

'''
這兩個(gè)函數(shù)是實(shí)參高階函數(shù)孤钦, 里面有個(gè)參數(shù)key要求傳一個(gè)函數(shù)
key參數(shù)對(duì)應(yīng)的函數(shù)是用來(lái)決定排序規(guī)則:函數(shù)需要一個(gè)參數(shù)和一個(gè)返回值歧斟,它的參數(shù)代表需要排序的序列的元素,返回值是比較對(duì)象
'''
數(shù)字列表, 排序規(guī)則發(fā)生改變: 按照數(shù)字的個(gè)位數(shù)從小到大排序

nums = [21, 69, 367, 78, 478, 5100]

print('11111111111111111111111111111111')
# key對(duì)應(yīng)的函數(shù)1: 按照元素本身大小進(jìn)行排序
# [21, 69, 367, 78, 478, 5100]
def func(item):
    return item

print('11111111111111111111111111')
# key對(duì)應(yīng)的函數(shù)2: 按照 元素%10 的值的大小進(jìn)行排序
def func1(item):
    return item % 10

print('2222222222222222222')
# key對(duì)應(yīng)的函數(shù)3:按照元素的最高位的值進(jìn)行從小到大排序
def func2(item):
    return int(str(item)[0])


nums.sort(key=func2)    # 按照元素本身大小進(jìn)行排序
print(nums)
print('2222222222222222222222222')

練習(xí): 給一個(gè)數(shù)字列表偏形,按照各位數(shù)的和的大小從下到大排序

nums = [12, 67, 18, 90, 890, 123, 99]    # [3, 13, 9, 9, 17, 6, 18]
# nums = [12, 123, 18, 90, 67, 890, 99]


def func3(item):
    sum1 = 0
    for ch in str(item):
        sum1 += int(ch)
    return sum1


nums.sort(key=func3)
print(nums)

練習(xí):

all_students = [
    {'name': '小明1', 'age': 23, 'score': 89, 'id': 'stu001'},
    {'name': '小明2', 'age': 30, 'score': 70, 'id': 'stu029'},
    {'name': '小明3', 'age': 18, 'score': 99, 'id': 'stu010'},
    {'name': '小明4', 'age': 21, 'score': 40, 'id': 'stu004'},
]


def func4(item):
    return item['score']


all_students.sort(key=func4, reverse=True)
print(all_students)
print('))))))))))))00000000000')
nums = [12, 39, 56]
print(max(nums, key=lambda item: item % 10))

print('0000000000000000000000000')
print(max(all_students, key=lambda item: item['score']))

print(max([1, 78, 9]))
print(max({90, 9, 100, 89}))
# print(max(all_students))   # TypeError: '>' not supported between instances of 'dict' and 'dict'
# print(max(all_students, key=10))   # TypeError: 'int' object is not callable
print(max(all_students, key=lambda x: x['score']))

迭代器

1.什么是迭代器(iter)

'''
迭代器是容器型類型(序列)构捡,可變(不支持增刪改),有序(不支持下標(biāo)操作)
保存在迭代器中的元素壳猜,只能取,并且取出來(lái)后滑凉,迭代器中就不再保存统扳,也不可以再往迭代器中添加元素

迭代器沒(méi)有對(duì)應(yīng)的格式的數(shù)據(jù)(沒(méi)有符號(hào)),迭代器只能是通過(guò)將其他的序列轉(zhuǎn)換成迭代器畅姊,或者是生成器

'''

iter1 = iter([10, 20, 30])
print(iter1)

iter2 = iter('hello')
print(iter2)

2.獲取迭代器中的元素

不管用什么方式取獲取迭代器中的元素咒钟,獲取一個(gè)少一個(gè)

1)獲取單個(gè)元素:next(迭代器) - 獲取迭代器中最頂層的元素(第一個(gè)元素)

print(next(iter2))   #  h
print(next(iter2))   #  e
print(next(iter2))   #  l
print(next(iter2))   #  l
print(next(iter2))   #  o

2)遍歷

iter2 = iter('abc123')
print(next(iter2))
print(next(iter2))
for x in iter2:
    print('====:', x)

生成器

1.什么是生成器

'''
生成器就是迭代器(迭代器不一定是生成器) - 獲取元素和迭代器一樣(一個(gè)一個(gè)取,取一個(gè)少一個(gè))
調(diào)用函數(shù)體中有yield關(guān)鍵字的函數(shù)若未,就可以得到一個(gè)生成器
'''

2.yield

'''
yield只能出現(xiàn)在函數(shù)體中
調(diào)用有yield關(guān)鍵字的函數(shù)朱嘴,不會(huì)執(zhí)行函數(shù)體,也不會(huì)獲取返回值,而是得到一個(gè)生成器

'''

def func1():
    yield
    print('我是一個(gè)函數(shù)')
    return 100


print(func1())
3.生成器怎么產(chǎn)生數(shù)據(jù)

'''
看一個(gè)生成器能夠產(chǎn)生幾個(gè)數(shù)據(jù)萍嬉,看執(zhí)行完生成器對(duì)應(yīng)后面的值就是生成器能產(chǎn)生數(shù)據(jù)的函數(shù)會(huì)遇到幾次yield;yield

'''

def func2():
    yield 'abc'
    yield 123

gen1 = func2()
print(gen1)
print(next(gen1))
print(next(gen1))


def func2():
    for x in range(10):
        yield x
gen1 = func2()
print(gen1)
print(next(gen1))
print(next(gen1))
print(next(gen1))

4.生成器生成數(shù)據(jù)的原理

'''
生成器不會(huì)同時(shí)將所有的元素保存起來(lái)乌昔,而是需要數(shù)據(jù)的時(shí)候臨時(shí)產(chǎn)生數(shù)據(jù)。
獲取生成器元素的時(shí)候壤追,就去執(zhí)行生成器對(duì)應(yīng)的函數(shù)的函數(shù)體磕道,從前往后執(zhí)行,直到遇到y(tǒng)ield為止行冰,
并且將yield后面的值作為結(jié)果溺蕉,同時(shí)保存結(jié)束位置;
下次獲取下一個(gè)元素的時(shí)候悼做,接著上次結(jié)束的位置往后執(zhí)行疯特,直到遇到下一個(gè)yield;
以此類推...
如果執(zhí)行到函數(shù)結(jié)束都沒(méi)有遇到y(tǒng)ield肛走,next函數(shù)會(huì)報(bào)StopIteration錯(cuò)誤
'''

def func3():
    print('第一個(gè)數(shù)據(jù)================')
    yield 1
    yield 2
    yield 3
    print('end')

gen2 = func3()
print(next(gen2))
print(next(gen2))
print(next(gen2))

寫(xiě)一個(gè)產(chǎn)生學(xué)號(hào)的生成器

def creat_id():
    num = 1
    while True:
        yield 'stu'+str(num)
        num += 1


nums = creat_id()
print(next(nums))

for _ in range(100):
    print(next(nums))

生成式

1.什么是生成式

'''
生成式本質(zhì)就是生成器
語(yǔ)法1:
(表達(dá)式 for 變量 in 序列)

展開(kāi)成生成器:
def func():
for 變量 in 序列:
yield 表達(dá)式

[表達(dá)式 for 變量 in 序列] - 將生成式對(duì)應(yīng)的生成器轉(zhuǎn)換成列表

語(yǔ)法2:
(表達(dá)式 for 變量 in 序列 if 條件語(yǔ)句) - 創(chuàng)建一個(gè)生成器

展開(kāi)生成器你:
def func1()
for 變量 in 序列:
if 條件語(yǔ)句:
yield 表達(dá)式

gen1 = (x*2 for x in range(10))


del func1():
    for x in range(10):
        yield x*2
gen1 = func()


print(next(gen1))
print(next(gen1))
print(next(gen1))
print(next(gen1))


list1 = list(gen1)
print(list1)
print('999999999999999999999999999999')
list2 = [x*x for x in range(1, 10)]
print(list2)
def func2():
    for x in range(1, 10):
        yield x*x

print(list2)

print('99999999999999999999999999999999')

list4 = [x for x in range(10) if x % 2]
print(list4)

def func5():
    for x in range(10):
        if x % 2:
            yield x
print(list4)


list5 = ['%d*2=%d' % (x, x*2) for x in range(5)]
print(list5)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末漓雅,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子羹与,更是在濱河造成了極大的恐慌故硅,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,430評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件纵搁,死亡現(xiàn)場(chǎng)離奇詭異吃衅,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)腾誉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,406評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門徘层,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人利职,你說(shuō)我怎么就攤上這事趣效。” “怎么了猪贪?”我有些...
    開(kāi)封第一講書(shū)人閱讀 167,834評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵跷敬,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我热押,道長(zhǎng)西傀,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,543評(píng)論 1 296
  • 正文 為了忘掉前任桶癣,我火速辦了婚禮拥褂,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘牙寞。我一直安慰自己饺鹃,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,547評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著悔详,像睡著了一般镊屎。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上伟端,一...
    開(kāi)封第一講書(shū)人閱讀 52,196評(píng)論 1 308
  • 那天杯道,我揣著相機(jī)與錄音,去河邊找鬼责蝠。 笑死党巾,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的霜医。 我是一名探鬼主播齿拂,決...
    沈念sama閱讀 40,776評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼肴敛!你這毒婦竟也來(lái)了署海?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,671評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤医男,失蹤者是張志新(化名)和其女友劉穎砸狞,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體镀梭,經(jīng)...
    沈念sama閱讀 46,221評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡刀森,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,303評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了报账。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片研底。...
    茶點(diǎn)故事閱讀 40,444評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖透罢,靈堂內(nèi)的尸體忽然破棺而出榜晦,到底是詐尸還是另有隱情,我是刑警寧澤羽圃,帶...
    沈念sama閱讀 36,134評(píng)論 5 350
  • 正文 年R本政府宣布乾胶,位于F島的核電站,受9級(jí)特大地震影響朽寞,放射性物質(zhì)發(fā)生泄漏胚吁。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,810評(píng)論 3 333
  • 文/蒙蒙 一愁憔、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧孽拷,春花似錦吨掌、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,285評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)窿侈。三九已至,卻和暖如春秋茫,著一層夾襖步出監(jiān)牢的瞬間史简,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,399評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工肛著, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留圆兵,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,837評(píng)論 3 376
  • 正文 我出身青樓枢贿,卻偏偏與公主長(zhǎng)得像殉农,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子局荚,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,455評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容

  • day_11_函數(shù)進(jìn)階 1.函數(shù)作為變量 python中聲明函數(shù)其實(shí)就是聲明一個(gè)類型是function的變量超凳,函數(shù)...
    生命在于不睡覺(jué)閱讀 153評(píng)論 0 0
  • 遞歸函數(shù) 實(shí)際開(kāi)發(fā)的時(shí)候,能不用遞歸就不用1.什么是遞歸函數(shù)函數(shù)中調(diào)用函數(shù)本身的函數(shù)就是遞歸函數(shù) 2.遞歸的作用:...
    嘩啦噼里啪啦閱讀 179評(píng)論 0 0
  • 你不知道JS:異步 第四章:生成器(Generators) 在第二章耀态,我們明確了采用回調(diào)表示異步流的兩個(gè)關(guān)鍵缺點(diǎn):...
    purple_force閱讀 967評(píng)論 0 2
  • 1.什么是生成式格式1: - 結(jié)果是一個(gè)生產(chǎn)器(迭代器)(表達(dá)式 for 變量 in 序列) --> 展開(kāi):def...
    9527神經(jīng)閱讀 132評(píng)論 0 0
  • 今天下載了《百度閱讀》轮傍,領(lǐng)了全本《東宮》,沒(méi)成想就這樣給看完了首装。 女主小楓的設(shè)定是個(gè)活潑天真單純的大涼菇?jīng)龃匆梗?..
    披件厚外套閱讀 732評(píng)論 0 0