自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

標準的Python語言進行說明介紹

開發(fā) 后端
Python 3.0發(fā)布七個月之后,Python核心開發(fā)人員于2009年6月27日發(fā)布了新的Python 3.1版本。雖然此3.1版本只是對Python 3.0的一次小型升級

Python語言具有一個標準的unittest模塊,可以用來編寫xUnit風(fēng)格的測試。您可以重復(fù)利用設(shè)置/拆卸代碼,以適當?shù)姆绞絹斫M織你的測試,甚至可以運行你的測試。下面是一個用于部分函數(shù)add5()的單元測試。

TestAdd5類由unittest.TestCase派生而來,并定義了一個setUp()方法,該方法將在執(zhí)行每個測試方法之前調(diào)用。它能確保某些一致狀態(tài)可以用于所有的測試方法。此測試方法會調(diào)用unittest的assertEqual()和assert_()方法。如果任何調(diào)用失敗,托管的測試方法就會認為出現(xiàn)了一個故障,并轉(zhuǎn)到下一個測試。

部分函數(shù)是一個惹人喜愛的函數(shù)特性。它們可以讓您的函數(shù)接收X個參數(shù)的函數(shù),同時,將一些參數(shù)固定,就能得到一個只能接收您沒規(guī)定的參數(shù)的新函數(shù)。下面舉例進行說明,函數(shù)add()可接收兩個參數(shù),并返回結(jié)果,現(xiàn)在如果把一個參數(shù)固定為5,我們就會得到一個新函數(shù)——僅僅接收一個參數(shù),代碼如下所示:

  1. Traceback (most recent call last):  
  2.   File "test_partial_pickle.py", line 12, in <module> 
  3.     s = pickle.dumps(partial(add, 10))  
  4.   File "/Library/Frameworks/Python.framework/Versions/  
  5.      2.5/lib/python2.5/pickle.py", line 1366, in dumps  
  6.      Pickler(file, protocol).dump(obj)  
  7.   File "/Library/Frameworks/Python.framework/Versions/  
  8.      2.5/lib/python2.5/pickle.py", line 224, in dump  
  9.      self.save(obj)  
  10.   File "/Library/Frameworks/Python.framework/Versions/  
  11.      2.5/lib/python2.5/pickle.py", line 306, in save  
  12.      rv = reduce(self.proto)  
  13.   File "/Library/Frameworks/Python.framework/Versions/  
  14.      2.5/lib/python2.5/copy_reg.py", line 69, in _reduce_ex  
  15.      raise TypeError, "can't pickle %s objects" % base.__name__  
  16. TypeError: can't pickle partial objects 

當使用要求參數(shù)總是相同的API的時候,部分函數(shù)會非常有用??梢钥紤]一個web應(yīng)用程序接口,在每個方法中都是要求一個用戶名和一個密碼。如果您創(chuàng)建一個固定了用戶名和口令的部分函數(shù),會給開發(fā)帶來非常大的便利,因為您不必傳遞參數(shù)了。

同時,您的代碼也會因此而變得更安全,因為用戶名和密碼不會出現(xiàn)在所有調(diào)用站點中。然而,直到Python 3.1為止,部分函數(shù)仍有許多讓人不快的限制。 因為它們無法封裝。好在Python 3.1解決了這個問題,下面是一個例子:

  1. Traceback (most recent call last):  
  2.   File "test_partial_pickle.py", line 12, in <module> 
  3.     s = pickle.dumps(partial(add, 10))  
  4.   File "/Library/Frameworks/Python.framework/Versions/  
  5.      2.5/lib/python2.5/pickle.py", line 1366, in dumps  
  6.      Pickler(file, protocol).dump(obj)  
  7.   File "/Library/Frameworks/Python.framework/Versions/  
  8.      2.5/lib/python2.5/pickle.py", line 224, in dump  
  9.      self.save(obj)  
  10.   File "/Library/Frameworks/Python.framework/Versions/  
  11.      2.5/lib/python2.5/pickle.py", line 306, in save  
  12.      rv = reduce(self.proto)  
  13.   File "/Library/Frameworks/Python.framework/Versions/  
  14.      2.5/lib/python2.5/copy_reg.py", line 69, in _reduce_ex  
  15.      raise TypeError, "can't pickle %s objects" % base.__name__  
  16. TypeError: can't pickle partial objects 

在使用processing模塊進行并行程序設(shè)計的時候,人們喜歡把函數(shù)和部分函數(shù)封裝起來。自Python 2.6以來,processing模塊已經(jīng)成為標準程序庫的一部分。是利用現(xiàn)代多核機器的***Python解決方案。實際上,processing模塊會封裝進程之間傳遞的所有一切,所以可封裝的部分函數(shù)提高了它的表達力并增加了可用的工具。

【編輯推薦】

  1. 漫談Python 源代碼編制技巧
  2. 簡單易于操作的Python 工具詳解
  3. 有關(guān)Python應(yīng)用領(lǐng)域進行說明介紹
  4. PythonAndroid面向?qū)ο蟮木幊獭狿ython應(yīng)用程序
  5. 如何使用Python模塊解析配置文件 ?
責(zé)任編輯:chenqingxiang 來源: 51CTO.com
相關(guān)推薦

2010-02-24 17:22:59

Python項目

2010-02-22 09:33:43

Python語言

2010-02-23 17:35:46

Python

2010-02-26 10:07:55

Python編程語言

2010-03-01 10:52:37

Python開發(fā)語言

2010-02-26 11:20:53

Python應(yīng)用

2010-03-01 16:32:36

Python語言

2010-01-05 16:41:48

JSON 標準

2010-01-06 15:30:51

JSON和XML

2010-02-26 09:33:51

Python腳本

2009-12-28 09:58:52

ADO操作

2009-12-25 15:28:48

ADO類

2009-12-25 09:25:54

ADO.NET實例

2010-01-05 13:29:50

JSON對象

2010-01-13 10:09:24

C++標準庫

2010-02-02 14:54:28

Python語法

2010-02-03 17:37:30

Python語法

2010-02-02 13:28:46

Python變量

2010-02-02 18:27:02

Python語言

2010-02-01 18:06:48

Python Edit
點贊
收藏

51CTO技術(shù)棧公眾號