Python学习笔记 ---第三章
函數(shù)
函數(shù)是代碼的一種抽象
| abs | 絕對值 |
| max | 最大值 |
| hex | 轉換為16進制 |
強制數(shù)據(jù)類型轉換
int('123')
123
int(12.35)
12
srt(100)
'100'
bool(1)
True
定義函數(shù)
定義一個函數(shù),依次寫出函數(shù)名,括號中的參數(shù)和冒號: 最后return返回
def my_abs(x):
if x >=0:
return x
else
return -x
*空函數(shù) 定義一個空函數(shù)
def nop()
pass
*返回多個值
import math
def move(x, y, step, angle=0):
nx = x + step * math.cos(angle)
ny = y - step * math.sin(angle)
return nx, ny
然會同時獲得返回值
x, y = move(100, 100, 60, math.pi / 6)
print(x, y)
151.96152422706632 70.0
這只是一種假象,Python函數(shù)返回的仍然是單一值
r = move(100, 100, 60, math.pi / 6)
print(r)
(151.96152422706632, 70.0)
返回了一個tuple
*定義函數(shù)時,要確定函數(shù)名和參數(shù)個數(shù),可以先對參數(shù)的數(shù)據(jù)類型進行檢查
函數(shù)體內(nèi)部可以用return隨時返回函數(shù)結果,沒有執(zhí)行完畢也沒有return語句時返回None
函數(shù)可以返回多個值,騎其實就是一個tuple
遞歸函數(shù)
*在函數(shù)內(nèi)部調(diào)用自身就是遞歸函數(shù)
def fact(n):
if n == 1
return 1
return n * fact(n-1)
*遞歸要防止棧溢出,可以用尾遞歸優(yōu)化防止溢出
def fact(n):
return fact_iter(n,1)
def fact_iter(num,product):
if num == 1:
return product
return fact_uter(num - 1,num*product)
return fact_iter(num - 1, num * product)僅返回遞歸函數(shù)本身,num - 1和num * product在函數(shù)調(diào)用前就會被計算,不影響函數(shù)調(diào)用。
使用遞歸函數(shù)的優(yōu)點是邏輯簡單清晰,缺點是過深的調(diào)用會導致棧溢出。
針對尾遞歸優(yōu)化的語言可以通過尾遞歸防止棧溢出。尾遞歸事實上和循環(huán)是等價的,沒有循環(huán)語句的編程語言只能通過尾遞歸實現(xiàn)循環(huán)。
高級函數(shù)
*切片
取出一個list中的部分元素
L = ['Michael', 'Sarah', 'Tracy', 'Bob', 'Jack']
L[0:3] #取出前三個元素,從0開始不包括3
['Michael', 'Sarah', 'Tracy']
L[-2] #倒序切片,從-1開始
['Bob', 'Jack']
建立一個0-99的數(shù)列
L = list(range(100))
L
[0,1,2,3,.....,99]
前十個,每兩個取一個
L[:10:2]
[0,2,4,6,8]
所有數(shù),每隔5個取一個
L[::5]
[0,5,10,.....,95]
tuple也可以進行切片,結果仍是一個tuple
(0,1,2,3,4,5)
[:3]
(0,1,2)
字符串'XXX'也可以看做list,可以進行切片
'ABCDEFG'[:3]
'ABC'
迭代
一個list或tuple,我們可以通過for循環(huán)來遍歷這個list或tuple,這種遍歷我們稱為迭代(Iteration)。
Python中通過for ... in 進行迭代
d = {'a':1,'b':2,'c':3}
for key in d:
print(key) #迭代出key
for value in d.values() #迭代value
for k,v in d.items() #迭代value 和key
collection模塊中的lterable類型判斷對象是否可以迭代
from collections import Iterable
isinstance('abc', Iterable) # str是否可迭代
True
Python內(nèi)置的enumerate函數(shù)可以把一個list變成索引-元素對,在for循環(huán)中同時迭代索引和元素本身
for i, value in enumerate(['A', 'B', 'C']):
print(i, value)
0 A
1 B
2 C
任何可迭代對象都可以作用于for循環(huán),包括我們自定義的數(shù)據(jù)類型,只要符合迭代條件,就可以使用for循環(huán)
列表生成式
list(range(1, 11))
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10] #生成1-10的list
生成[1x1, 2x2, 3x3, ..., 10x10]
1.循環(huán)
L = []
for x in range(1, 11):
L.append(x * x)
L
[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
2.list
[x*x for x in range(1,11)]
[1,4,16,25, 36, 49, 64, 81, 100]
for循環(huán)后面還可以加上if判斷,這樣我們就可以篩選出僅偶數(shù)的平方
[x*x for x in range(1,11) if x%2 == 0]
[4,16,36,64,100]
兩層循環(huán)生成全排列
[m + n for m in 'ABC' n in 'XYZ']
['AX', 'AY', 'AZ', 'BX', 'BY', 'BZ', 'CX', 'CY', 'CZ']
列表生成式可使用兩個變量生成list
d = {'x':,'A','y':'B','z',:'C'}
[k + '=' + v for k,v in d.items()]
['y=B','x=A','z=C']
生成器
在Python中一邊循環(huán)一邊計算的機制,稱為生成器:generator
把列表生成器的[]改為()就建立了一個generator
L = [x * x for x in range(10)]
g = (x * x for x in range(10))
通過next() 獲得generator的下一個返回值
next(g)
0
next(g)
1
next(g)
4
然后加入for循環(huán)
g = (x * x for x in range(10))
for n in g:
print (n)
0
1
4
16
斐波拉契數(shù)列
def fib(max):
n,a,b =0,0,1
while n < max:
print(b)
a,b = b,a+b
n = n+1
return 'done'
轉載于:https://www.cnblogs.com/battleblock/p/4817451.html
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎勵來咯,堅持創(chuàng)作打卡瓜分現(xiàn)金大獎總結
以上是生活随笔為你收集整理的Python学习笔记 ---第三章的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: iOS push新的调用方法
- 下一篇: python实现: protobuf解释