激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - 簡單的Python2.7編程初學經驗總結

簡單的Python2.7編程初學經驗總結

2020-05-27 09:55rustyrazorblade Python

這篇文章主要是作者寫給Python2.7編程初學者的經驗總結,側重于包管理、代碼調試等實際使用方面,需要的朋友可以參考下

如果你從來沒有使用過Python,我強烈建議你閱讀Python introduction,因為你需要知道基本的語法和類型。
包管理

Python世界最棒的地方之一,就是大量的第三方程序包。同樣,管理這些包也非常容易。按照慣例,會在 requirements.txt 文件中列出項目所需要的包。每個包占一行,通常還包含版本號。這里有一個例子,本博客使用Pelican:
 

?
1
2
3
pelican==3.3
Markdown
pelican-extended-sitemap==1.0.0

Python 程序包有一個缺陷是,它們默認會進行全局安裝。我們將要使用一個工具,使我們每個項目都有一個獨立的環境,這個工具叫virtualenv。我們同樣要安裝一個更高級的包管理工具,叫做pip,他可以和virtualenv配合工作。

首先,我們需要安裝pip。大多數python安裝程序已經內置了easy_install(python默認的包管理工具),所以我們就使用easy_install pip來安裝pip。這應該是你最后一次使用easy_install 了。如果你并沒有安裝easy_install ,在linux系統中,貌似從python-setuptools 包中可以獲得。

如果你使用的Python版本高于等于3.3, 那么Virtualenv 已經是標準庫的一部分了,所以沒有必要再去安裝它了。

下一步,你希望安裝virtualenv和virtualenvwrapper。Virtualenv使你能夠為每個項目創造一個獨立的環境。尤其是當你的不同項目使用不同版本的包時,這一點特別有用。Virtualenv wrapper 提供了一些不錯的腳本,可以讓一些事情變得容易。

?
1
sudo pip install virtualenvwrapper

當virtualenvwrapper安裝后,它會把virtualenv列為依賴包,所以會自動安裝。

打開一個新的shell,輸入mkvirtualenv test 。如果你打開另外一個shell,則你就不在這個virtualenv中了,你可以通過workon test 來啟動。如果你的工作完成了,可以使用deactivate 來停用。

簡單的Python2.7編程初學經驗總結

IPython

IPython是標準Python交互式的編程環境的一個替代品,支持自動補全,文檔快速訪問,以及標準交互式編程環境本應該具備的很多其他功能。

當你處在一個虛擬環境中的時候,可以很簡單的使用pip install ipython 來進行安裝,在命令行中使用ipython 來啟動

簡單的Python2.7編程初學經驗總結

另一個不錯的功能是”筆記本”,這個功能需要額外的組件。安裝完成后,你可以使用ipython notebook,而且會有一個不錯的網頁UI,你可以創建筆記本。這在科學計算領域很流行。

簡單的Python2.7編程初學經驗總結

測試

我推薦使用nose或是py.test。我大部分情況下用nose。它們基本上是類似的。我將講解nose的一些細節。

這里有一個人為創建的可笑的使用nose進行測試的例子。在一個以test_開頭的文件中的所有以test_開頭的函數,都會被調用:
 

?
1
2
def test_equality():
  assert True == False

不出所料,當運行nose的時候,我們的測試沒有通過。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
(test)jhaddad@jons-mac-pro ~VIRTUAL_ENV/src$ nosetests                                                                  
F
======================================================================
FAIL: test_nose_example.test_equality
----------------------------------------------------------------------
Traceback (most recent call last):
 File "/Users/jhaddad/.virtualenvs/test/lib/python2.7/site-packages/nose/case.py", line 197, in runTest
  self.test(*self.arg)
 File "/Users/jhaddad/.virtualenvs/test/src/test_nose_example.py", line 3, in test_equality
  assert True == False
AssertionError
 
----------------------------------------------------------------------

nose.tools中同樣也有一些便捷的方法可以調用
 

?
1
2
3
from nose.tools import assert_true
def test_equality():
  assert_true(False)

如果你想使用更加類似JUnit的方法,也是可以的:
 

?
1
2
3
4
5
6
7
8
9
10
from nose.tools import assert_true
from unittest import TestCase
 
class ExampleTest(TestCase):
 
  def setUp(self): # setUp & tearDown are both available
    self.blah = False
 
  def test_blah(self):
    self.assertTrue(self.blah)

開始測試:
 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
(test)jhaddad@jons-mac-pro ~VIRTUAL_ENV/src$ nosetests                                                                  
F
======================================================================
FAIL: test_blah (test_nose_example.ExampleTest)
----------------------------------------------------------------------
Traceback (most recent call last):
 File "/Users/jhaddad/.virtualenvs/test/src/test_nose_example.py", line 11, in test_blah
  self.assertTrue(self.blah)
AssertionError: False is not true
 
----------------------------------------------------------------------
Ran 1 test in 0.003s
 
FAILED (failures=1)

卓越的Mock庫包含在Python 3 中,但是如果你在使用Python 2,可以使用pypi來獲取。這個測試將進行一個遠程調用,但是這次調用將耗時10s。這個例子顯然是人為捏造的。我們使用mock來返回樣本數據而不是真正的進行調用。
 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
import mock
 
from mock import patch
from time import sleep
 
class Sweetness(object):
  def slow_remote_call(self):
    sleep(10)
    return "some_data" # lets pretend we get this back from our remote api call
 
def test_long_call():
  s = Sweetness()
  result = s.slow_remote_call()
  assert result == "some_data"

當然,我們的測試需要很長的時間。
 

?
1
2
3
4
5
(test)jhaddad@jons-mac-pro ~VIRTUAL_ENV/src$ nosetests test_mock.py                                                           
 
Ran 1 test in 10.001s
 
OK

太慢了!因此我們會問自己,我們在測試什么?我們需要測試遠程調用是否有用,還是我們要測試當我們獲得數據后要做什么?大多數情況下是后者。讓我們擺脫這個愚蠢的遠程調用吧:
 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
import mock
 
from mock import patch
from time import sleep
 
class Sweetness(object):
  def slow_remote_call(self):
    sleep(10)
    return "some_data" # lets pretend we get this back from our remote api call
 
def test_long_call():
  s = Sweetness()
  with patch.object(s, "slow_remote_call", return_value="some_data"):
    result = s.slow_remote_call()
  assert result == "some_data"

好吧,讓我們再試一次:
 

?
1
2
3
4
5
6
(test)jhaddad@jons-mac-pro ~VIRTUAL_ENV/src$ nosetests test_mock.py                                                           
.
----------------------------------------------------------------------
Ran 1 test in 0.001s
 
OK

好多了。記住,這個例子進行了荒唐的簡化。就我個人來講,我僅僅會忽略從遠程系統的調用,而不是我的數據庫調用。

nose-progressive是一個很好的模塊,它可以改善nose的輸出,讓錯誤在發生時就顯示出來,而不是留到最后。如果你的測試需要花費一定的時間,那么這是件好事。
pip install nose-progressive 并且在你的nosetests中添加--with-progressive
調試

iPDB是一個極好的工具,我已經用它查出了很多匪夷所思的bug。pip install ipdb 安裝該工具,然后在你的代碼中import ipdb; ipdb.set_trace(),然后你會在你的程序運行時,獲得一個很好的交互式提示。它每次執行程序的一行并且檢查變量。

簡單的Python2.7編程初學經驗總結

python內置了一個很好的追蹤模塊,幫助我搞清楚發生了什么。這里有一個沒什么用的python程序:
 

?
1
2
3
a = 1
b = 2
a = b

這里是對這個程序的追蹤結果:
 

?
1
2
3
4
5
6
7
(test)jhaddad@jons-mac-pro ~VIRTUAL_ENV/src$ python -m trace --trace tracing.py                                                    1 ?
 --- modulename: tracing, funcname: <module>
tracing.py(1): a = 1
tracing.py(2): b = 2
tracing.py(3): a = b
 --- modulename: trace, funcname: _unsettrace
trace.py(80):     sys.settrace(None)

當你想要搞清楚其他程序的內部構造的時候,這個功能非常有用。如果你以前用過strace,它們的工作方式很相像

在一些場合,我使用pycallgraph來追蹤性能問題。它可以創建函數調用時間和次數的圖表。

簡單的Python2.7編程初學經驗總結

最后,objgraph對于查找內存泄露非常有用。這里有一篇關于如何使用它查找內存泄露的好文。
Gevent

Gevent 是一個很好的庫,封裝了Greenlets,使得Python具備了異步調用的功能。是的,非常棒。我最愛的功能是Pool,它抽象了異步調用部分,給我們提供了可以簡單使用的途徑,一個異步的map()函數:
 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
from gevent import monkey
monkey.patch_all()
 
from time import sleep, time
 
def fetch_url(url):
  print "Fetching %s" % url
  sleep(10)
  print "Done fetching %s" % url
 
from gevent.pool import Pool
 
urls = ["http://test.com", "http://bacon.com", "http://eggs.com"]
 
p = Pool(10)
 
start = time()
p.map(fetch_url, urls)
print time() - start

非常重要的是,需要注意這段代碼頂部對gevent monkey進行的補丁,如果沒有它的話,就不能正確的運行。如果我們讓Python連續調用 fetch_url 3次,通常我們期望這個過程花費30秒時間。使用gevent:
 

?
1
2
3
4
5
6
7
8
(test)jhaddad@jons-mac-pro ~VIRTUAL_ENV/src$ python g.py                                                                 
Fetching http://test.com
Fetching http://bacon.com
Fetching http://eggs.com
Done fetching http://test.com
Done fetching http://bacon.com
Done fetching http://eggs.com
10.001791954

如果你有很多數據庫調用或是從遠程URLs獲取,這是非常有用的。我并不是很喜歡回調函數,所以這一抽象對我來說效果很好。
結論

好吧,如果你看到這里了,那么你很可能已經學到了一些新東西。這些工具,在過去的一年里對我影響重大。找打它們花費了不少時間,所以希望本文能夠減少其他人想要很好利用這門語言需要付出的努力。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 粉嫩蜜桃麻豆免费大片 | 成人免费毛片在线观看 | 中文字幕线观看 | 欧美囗交 | 日日草夜夜| 午夜视频大全 | 成人小视频在线播放 | 91精品国产一区二区在线观看 | 免费观看高清视频网站 | 久久久久久久久浪潮精品 | 欧美黄色一级生活片 | 日本中文高清 | 国产激情精品一区二区三区 | 国产免费一区二区三区在线能观看 | 久久综合九色综合久久久精品综合 | 免费a级毛片大学生免费观看 | 亚洲码无人客一区二区三区 | 欧美日韩专区国产精品 | 国产精品久久久久久影院8一贰佰 | 操操操操操 | 一级大片在线观看 | 欧美在线观看视频一区二区 | 欧产日产国产精品乱噜噜 | 一区二区三区黄色 | 国产精品久久久久免费视频 | 欧美日韩国产精品 | 久色婷婷| 毛片免费网 | 久久福利剧场 | 国产亚洲欧美日韩在线观看不卡 | 国产亚洲美女精品久久久2020 | 国产孕妇孕交大片孕 | 91成 | 女教师~淫辱の动漫在线 | 一二区成人影院电影网 | 青草av.久久免费一区 | 一级毛片免费在线 | 成人aaaa免费全部观看 | 做羞羞视频 | 九一免费国产 | 国产毛片网 |