基礎拾遺 序列解包 例: >>>x,y,z=1,2,3 >>>print x,y,z 1 2 3 交換變數也是沒問題 >>>x,y=y,x >>>print x,y,z 2 1 3 #這個很實用 當函數或方法返回元組(或其它序列或可迭代對象)時,這個特性特別有用。假如需要獲取(和刪除)字典中任意的鍵...
基礎拾遺
序列解包
例:
>>>x,y,z=1,2,3 >>>print x,y,z 1 2 3
交換變數也是沒問題
>>>x,y=y,x >>>print x,y,z 2 1 3 #這個很實用當函數或方法返回元組(或其它序列或可迭代對象)時,這個特性特別有用。假如需要獲取(和刪除)字典中任意的鍵-值對,可以使用popitem方法,將鍵值對作為元組返回,那麼就可以直接賦值到兩變數中
例:
>>> dic1={'name':'lzl','girlfriend':'None'} >>> key,value=dic1.popitem() >>> print key,value girlfriend None
賦值時要求序列中的元素和=左邊的變數數量一致,否則引發異常valueError
註:python 3.0另一解包特性:允許像在函數中的參數列表中一樣使用星號,例如 a,b,*test=[1,2,3,4,5],這樣test的結果是[3,4,5]
鏈式賦值
是將同一值賦值給多變數的捷徑。
x=y=somefunction() 等同於 y=somefunction() x=y 但與如下不一定等同: x=somefunction() y=somefunction()
布爾值知識補充
標準值False、None、所有類型的數字0、空序列、空字典都為假;其它一切為真,包括特殊值True
name=''
while not name or name.isspace() :
name = raw_input('please input your name:')
print 'hello,%s' % name
實用:在做判斷輸入是否為空時,輸入了空格會判斷為真,卻又不易察覺,可以使用while not name or name.isspace()或while not name.strip()
斷言
如果需要確保程式中某條件為真才能繼續運行,assert語句就有用了,相當於if語句做了一次判斷
例子:
>>> age = 1 >>> assert 0<age <10 >>> age = -1 >>> assert 0<age<10,'The age must be realistic' Traceback (most recent call last): File "<input>", line 1, in <module> AssertionError: The age must be realistic
一些迭代工具
在python中迭代序列(或其它可迭代對象),有一些函數非常好用
1.並行迭代
names = ['lzl','Bruce Li','damon'] age = [18,20,28] print zip(names,ages)
輸出:[('lzl', 18), ('Bruce Li', 20), ('damon', 28)]
內建的zip函數可用來並行迭代,像是上面介紹序列解包的相反過程
重要的一點是zip可處理不等長的序列,當最短的序列“用完”的時候就停止。
>>> zip(range(5),xrange(100))
[(0, 0), (1, 1), (2, 2), (3, 3), (4, 4)]
2.按索引迭代
有些時候想要迭代序列中的對象,同時還要獲取對象對應的索引。這時內建函數enumerate可以在提供索引的地方迭代索引-值對,預設索引從0開始
例子:
>>> li=['北京','四川','重慶'] >>> for index,string in enumerate(li,1): #索引從1開始 ... print index,"---",string ... 1 --- 北京 2 --- 四川 3 --- 重慶
實用:可用作菜單選項製作
3.翻轉和排序迭代
函數reserved和sorted同列表的reserve和sort方法類似,但作用於任何和序列或可迭代對象上,不是原地修改對象,而是返回翻轉或排序後的版本
例子:
>>> list1=[4,3,6,2,1] >>> sorted(list1) [1, 2, 3, 4, 6] >>> list1 #list1沒有改變 [4, 3, 6, 2, 1] >>> reversed(list1) <listreverseiterator object at 0x02A98C70> >>> list1 #list1沒有改變 [4, 3, 6, 2, 1]
註意:sorted方法返回列表,而reserved返回一個可迭代對象
列表推導式--輕量級迴圈
列表推導式(list comprehension)是利用其它列表創建新列表(類似數學術語中的集合推導式)的一種方法。
>>> [x*x for x in range(10)] [0, 1, 4, 9, 16, 25, 36, 49, 64, 81] >>> [x*x for x in range(10) if x % 3 == 0] #輸出能被3整除的 [0, 9, 36, 81]
對比,以for語句創建列表:
result = [] for a in range(3): for b in range(3): result.append((a,b)) print result
輸出:[(0, 0), (0, 1), (0, 2), (1, 0), (1, 1), (1, 2), (2, 0), (2, 1), (2, 2)]
例:
>>> girls=['alice','bernice','clarice'] >>> boys=['chris','arnold','bob'] >>> [b+'+'+g for b in boys for g in girls if b[0] == g[0]] #要求得到首字母相同的男孩女孩 ['chris+clarice', 'arnold+alice', 'bob+bernice']
函數
內置函數
vars():顯示當前模塊的變數,比如
__file__:路徑
__doc__:當前模塊的註釋
__name__:被執行的腳本__name__值=__main__,代表就是主函數(程式入口)
id():顯示記憶體地址 is:比對兩值得記憶體地址
all():接受一個序列,如果內部所有的值都是真的,返回真,否則返回假;用於用戶輸入判定
any():接受一個序列,只要內部元素有一個真,返回真
ord():接受一個字元返回ascci碼對應值 相反chr()
hex():轉換十進位成16進位 oct():轉換十進位成8進位 bin():轉換十進位成2進位
自定義函數
while True: if cpu利用率 > 90%: #發送郵件提醒 連接郵箱伺服器 發送郵件 關閉連接 if 硬碟使用空間 > 90%: #發送郵件提醒 連接郵箱伺服器 發送郵件 關閉連接 if 記憶體占用 > 80%: #發送郵件提醒 連接郵箱伺服器 發送郵件 關閉連接
上述代碼,if條件語句下的內容可以被提取出來公用,如下:
def 發送郵件(內容) #發送郵件提醒 連接郵箱伺服器 發送郵件 關閉連接 while True: if cpu利用率 > 90%: 發送郵件('CPU報警') if 硬碟使用空間 > 90%: 發送郵件('硬碟報警') if 記憶體占用 > 80%:
對於上述的兩種實現方式,第二次必然比第一次的重用性和可讀性要好,其實這就是函數式編程和麵向過程編程的區別:
- 函數式:將某功能代碼封裝到函數中,日後便無需重覆編寫,僅調用函數即可
- 面向對象:對函數進行分類和封裝,讓開發“更快更好更強...”
函數式編程最重要的是增強代碼的重用性和可讀性
函數的定義主要有如下要點:
- · def:表示函數的關鍵字
- · 函數名:函數的名稱,日後根據函數名調用函數
- · 函數體:函數中進行一系列的邏輯計算,如:發送郵件、計算出 [11,22,38,888,2]中的最大數等...不自動執行,調用後才執行
- · 參數:為函數體提供數據
- · 返回值:當函數執行完畢後,可以給調用者返回數據。如果沒有指定返回值,返回None
def 函數名(參數): ... 函數體 ...
返回值
所有的函數都返回了東西,沒有指定返回值時返回None
>>> def test(): print 'this is printed' return #return後沒接任何參數,起到結束函數作用 print 'this is not' >>> x=test() this is printed
參數
形式參數:寫在def語句中函數名後的變數
註:參數只是變數而已,在函數內為參數賦予新值不會改變外部任何變數的值,即局部作用域(local scope);
實際參數:調用函數時提供的實參
預設參數:必須放到最後,可以有多個
動態參數:
第1種
>>> def func(*args): print args >>> func(18) (18,) >>> func(18,'qq') (18, 'qq') >>> li=[1,2,'a'] >>> func(li) ([1, 2, 'a'],) >>> func(*li) (1, 2, 'a')特點:
- 可以接受多個參數;
- 內部自動構造元組,即返回元組類型
- 序列前加*避免內部構造元組
第2種
>>> def func(**args): ... print args ... >>> func(123) Traceback (most recent call last): File "<input>", line 1, in <module> TypeError: func() takes exactly 0 arguments (1 given) >>> func(k1=123,k2='abc') #以key=value形式傳入參數 {'k2': 'abc', 'k1': 123} >>> dic={'k1':18,'k2':'lzl'} >>> func(dic) Traceback (most recent call last): File "<input>", line 1, in <module> TypeError: func() takes exactly 0 arguments (1 given) >>> func(**dic) #傳入字典類型時,加** {'k2': 'lzl', 'k1': 18}
特點:
1.只接受key=value的參數
2.當是字典時,加**
通過以上驗證得出動態參數除了是單值就是‘key=value’形式,因此如果結合使用就強大了,同字元串的forma()方法
>>> help(str.format) Help on method_descriptor: format(...) S.format(*args, **kwargs) -> string Return a formatted version of S, using substitutions from args and kwargs. The substitutions are identified by braces ('{' and '}').
以上內容參考《python基礎教程第二版》和武sir博客http://www.cnblogs.com/wupeiqi/articles/4943406.html 整理完成,主要記錄要點。