Python学习笔记:Day13 提升开发效率
前言
最近在學(xué)習(xí)深度學(xué)習(xí),已經(jīng)跑出了幾個(gè)模型,但Pyhton的基礎(chǔ)不夠扎實(shí),因此,開(kāi)始補(bǔ)習(xí)Python了,大家都推薦廖雪峰的課程,因此,開(kāi)始了學(xué)習(xí),但光學(xué)有沒(méi)有用,還要和大家討論一下,因此,寫下這些帖子,廖雪峰的課程連接在這里:廖雪峰
Python的相關(guān)介紹,以及它的歷史故事和運(yùn)行機(jī)制,可以參見(jiàn)這篇:python介紹
Python的安裝可以參見(jiàn)這篇:Python安裝
Python的運(yùn)行模式以及輸入輸出可以參見(jiàn)這篇:Python IO
Python的基礎(chǔ)概念介紹,可以參見(jiàn)這篇:Python 基礎(chǔ)
Python字符串和編碼的介紹,可以參見(jiàn)這篇:Python字符串與編碼
Python基本數(shù)據(jù)結(jié)構(gòu):list和tuple介紹,可以參見(jiàn)這篇:Python list和tuple
Python控制語(yǔ)句介紹:ifelse,可以參見(jiàn)這篇:Python 條件判斷
Python控制語(yǔ)句介紹:循環(huán)實(shí)現(xiàn),可以參見(jiàn)這篇:Python循環(huán)語(yǔ)句
Python數(shù)據(jù)結(jié)構(gòu):dict和set介紹Python數(shù)據(jù)結(jié)構(gòu)dict和set
Python函數(shù)相關(guān):Python函數(shù)
Python高階特性:Python高級(jí)特性
Python高階函數(shù):Python高階函數(shù)
Python匿名函數(shù):Python匿名函數(shù)
Python裝飾器:Python裝飾器
Python偏函數(shù):Python偏函數(shù)
Python模塊:Python模塊
Python面向?qū)ο缶幊?#xff08;1):Python面向?qū)ο?
Python面向?qū)ο缶幊?#xff08;2):Python面向?qū)ο?#xff08;2)
Python面向?qū)ο缶幊?#xff08;3):Python面向?qū)ο?#xff08;3)
Python面向?qū)ο缶幊?#xff08;4):Pyhton面向?qū)ο?#xff08;4)
Python面向?qū)ο蟾呒?jí)編程(上):Python面向?qū)ο蟾呒?jí)編程(上)
Python面向?qū)ο蟾呒?jí)編程(中上):Python面向?qū)ο蟾呒?jí)編程(中上)
Python面向?qū)ο蟾呒?jí)編程(中下):Python面向?qū)ο蟾呒?jí)編程(中下)
Python面向?qū)ο蟾呒?jí)編程(完):Python面向?qū)ο蟾呒?jí)編程(完)
Python錯(cuò)誤調(diào)試(起):Python調(diào)試:起
Python錯(cuò)誤調(diào)試(承):Python調(diào)試:承
Python錯(cuò)誤調(diào)試(轉(zhuǎn)):Python調(diào)試:轉(zhuǎn)
Python錯(cuò)誤調(diào)試(合):python調(diào)試:合
Python文件IO編程:Python文件IO
Python文件IO編程2:Python文件IO2
Python文件IO編程3:PYthon文件IO3
Python進(jìn)程和線程(起):Python進(jìn)程和線程起
Python進(jìn)程和線程(承):Python進(jìn)程和線程承
Python進(jìn)程和線程(轉(zhuǎn)):Python進(jìn)程和線程轉(zhuǎn)
Python進(jìn)程和線程(合):Python進(jìn)程和線程合
Python正則表達(dá)式:Python正則表達(dá)式
Python學(xué)習(xí)筆記:常用內(nèi)建模塊1:Python學(xué)習(xí)筆記:常用內(nèi)建模塊1
Python學(xué)習(xí)筆記:常用內(nèi)建模塊2:Python學(xué)習(xí)筆記:常用內(nèi)建模塊2
Python學(xué)習(xí)筆記:常用內(nèi)建模塊3:Python學(xué)習(xí)筆記:常用內(nèi)建模塊3
Python學(xué)習(xí)筆記:常用內(nèi)建模塊4:Python學(xué)習(xí)筆記: 常用內(nèi)建模塊4
Python學(xué)習(xí)筆記:常用內(nèi)建模塊5:Python學(xué)習(xí)筆記: 常用內(nèi)建模塊5
Python學(xué)習(xí)筆記:常用內(nèi)建模塊6:Python學(xué)習(xí)筆記:常用內(nèi)建模塊6
Python學(xué)習(xí)筆記:第三方模塊1:Python常用第三方模塊
Python學(xué)習(xí)筆記:第三方模塊2:Python常用第三方模塊
Python學(xué)習(xí)筆記:第三方模塊3:Python常用第三方模塊
Pytho學(xué)習(xí)筆記:網(wǎng)絡(luò)編程:Python網(wǎng)絡(luò)編程
Python學(xué)習(xí)筆記:電子郵件:Python電子郵件1
Python學(xué)習(xí)筆記:SMTP服務(wù)器:PythonSMTP服務(wù)器
Python學(xué)習(xí)筆記:POP3服務(wù)器:PythonPOP3服務(wù)器
Python學(xué)習(xí)筆記:Python數(shù)據(jù)庫(kù) Python數(shù)據(jù)庫(kù)1
Python學(xué)習(xí)筆記:Python數(shù)據(jù)庫(kù)2Python數(shù)據(jù)庫(kù)2
Python學(xué)習(xí)筆記:web開(kāi)發(fā)1Python學(xué)習(xí)筆記:web開(kāi)發(fā)1
Python學(xué)習(xí)筆記:web開(kāi)發(fā)2Python學(xué)習(xí)筆記: web開(kāi)發(fā)2
Python學(xué)習(xí)筆記: web開(kāi)發(fā)3Python學(xué)習(xí)筆記: web開(kāi)發(fā)3
Python學(xué)習(xí)筆記:異步IO(1)Python學(xué)習(xí)筆記:異步IO(1)
Python學(xué)習(xí)筆記:異步IO(2)Python學(xué)習(xí)筆記:異步IO(2)
Python學(xué)習(xí)筆記:異步IO(3)Python學(xué)習(xí)筆記:異步IO(3)
Python學(xué)習(xí)筆記:Day 1-2開(kāi)發(fā)Python學(xué)習(xí)筆記:Day1-2開(kāi)發(fā)
Python學(xué)習(xí)筆記:Day 3 ORMPython學(xué)習(xí)筆記:Day3 ORM
Python學(xué)習(xí)筆記:Day 4 ModelPython學(xué)習(xí)筆記:Day4Model
Python學(xué)習(xí)筆記:Day 5 web框架PYTHON學(xué)習(xí)筆記:DAy5
Python學(xué)習(xí)筆記:Day 6 配置文件Python學(xué)習(xí)筆記:Day 6 配置文件
Python學(xué)習(xí)筆記:Day 7 編寫MVCPython學(xué)習(xí)筆記:Day 7編寫MVC
Python學(xué)習(xí)筆記:Day 8 構(gòu)建前端Python學(xué)習(xí)筆記:Day 8 構(gòu)建前端
Python學(xué)習(xí)筆記:Day 9 編寫APIPython 9編寫API
Python學(xué)習(xí)筆記:Day 10 用戶注冊(cè)和登陸Python 10用戶注冊(cè)和登陸
Python學(xué)習(xí)筆記:Day11 編寫日志創(chuàng)建頁(yè)day11 編寫目錄
Python學(xué)習(xí)筆記:Day12 編寫日志列表頁(yè)day12 編寫日志
目錄
- 前言
- 目錄
- 提升開(kāi)發(fā)效率
提升開(kāi)發(fā)效率
現(xiàn)在,我們已經(jīng)把一個(gè)Web App的框架完全搭建好了,從后端的API到前端的MVVM,流程已經(jīng)跑通了。
在繼續(xù)工作前,注意到每次修改Python代碼,都必須在命令行先Ctrl-C停止服務(wù)器,再重啟,改動(dòng)才能生效。
在開(kāi)發(fā)階段,每天都要修改、保存幾十次代碼,每次保存都手動(dòng)來(lái)這么一下非常麻煩,嚴(yán)重地降低了我們的開(kāi)發(fā)效率。有沒(méi)有辦法讓服務(wù)器檢測(cè)到代碼修改后自動(dòng)重新加載呢?
Django的開(kāi)發(fā)環(huán)境在Debug模式下就可以做到自動(dòng)重新加載,如果我們編寫的服務(wù)器也能實(shí)現(xiàn)這個(gè)功能,就能大大提升開(kāi)發(fā)效率。
可惜的是,Django沒(méi)把這個(gè)功能獨(dú)立出來(lái),不用Django就享受不到,怎么辦?
其實(shí)Python本身提供了重新載入模塊的功能,但不是所有模塊都能被重新載入。另一種思路是檢測(cè)www目錄下的代碼改動(dòng),一旦有改動(dòng),就自動(dòng)重啟服務(wù)器。
按照這個(gè)思路,我們可以編寫一個(gè)輔助程序pymonitor.py,讓它啟動(dòng)wsgiapp.py,并時(shí)刻監(jiān)控www目錄下的代碼改動(dòng),有改動(dòng)時(shí),先把當(dāng)前wsgiapp.py進(jìn)程殺掉,再重啟,就完成了服務(wù)器進(jìn)程的自動(dòng)重啟。
要監(jiān)控目錄文件的變化,我們也無(wú)需自己手動(dòng)定時(shí)掃描,Python的第三方庫(kù)watchdog可以利用操作系統(tǒng)的API來(lái)監(jiān)控目錄文件的變化,并發(fā)送通知。我們先用pip安裝:
$ pip3 install watchdog利用watchdog接收文件變化的通知,如果是.py文件,就自動(dòng)重啟wsgiapp.py進(jìn)程。
利用Python自帶的subprocess實(shí)現(xiàn)進(jìn)程的啟動(dòng)和終止,并把輸入輸出重定向到當(dāng)前進(jìn)程的輸入輸出中:
#!/usr/bin/env python3 # -*- coding: utf-8 -*-__author__ = 'Mike Li'import os, sys, time, subprocessfrom watchdog.observers import Observer from watchdog.events import FileSystemEventHandlerdef log(s):print('[Monitor] %s' % s)class MyFileSystemEventHander(FileSystemEventHandler):def __init__(self, fn):super(MyFileSystemEventHander, self).__init__()self.restart = fndef on_any_event(self, event):if event.src_path.endswith('.py'):log('Python source file changed: %s' % event.src_path)self.restart()command = ['echo', 'ok'] process = Nonedef kill_process():global processif process:log('Kill process [%s]...' % process.pid)process.kill()process.wait()log('Process ended with code %s.' % process.returncode)process = Nonedef start_process():global process, commandlog('Start process %s...' % ' '.join(command))process = subprocess.Popen(command, stdin=sys.stdin, stdout=sys.stdout, stderr=sys.stderr)def restart_process():kill_process()start_process()def start_watch(path, callback):observer = Observer()observer.schedule(MyFileSystemEventHander(restart_process), path, recursive=True)observer.start()log('Watching directory %s...' % path)start_process()try:while True:time.sleep(0.5)except KeyboardInterrupt:observer.stop()observer.join()if __name__ == '__main__':argv = sys.argv[1:]if not argv:print('Usage: ./pymonitor your-script.py')exit(0)if argv[0] != 'python3':argv.insert(0, 'python3')command = argvpath = os.path.abspath('.')start_watch(path, None)一共70行左右的代碼,就實(shí)現(xiàn)了Debug模式的自動(dòng)重新加載。用下面的命令啟動(dòng)服務(wù)器:
$ python3 pymonitor.py wsgiapp.py或者給pymonitor.py加上可執(zhí)行權(quán)限,啟動(dòng)服務(wù)器:
$ ./pymonitor.py app.py在編輯器中打開(kāi)一個(gè).py文件,修改后保存,看看命令行輸出,是不是自動(dòng)重啟了服務(wù)器:
$ ./pymonitor.py app.py [Monitor] Watching directory /Users/michael/Github/awesome-python3-webapp/www... [Monitor] Start process python app.py... ... INFO:root:application (/Users/michael/Github/awesome-python3-webapp/www) will start at 0.0.0.0:9000... [Monitor] Python source file changed: /Users/michael/Github/awesome-python-webapp/www/handlers.py [Monitor] Kill process [2747]... [Monitor] Process ended with code -9. [Monitor] Start process python app.py... ... INFO:root:application (/Users/michael/Github/awesome-python3-webapp/www) will start at 0.0.0.0:9000...現(xiàn)在,只要一保存代碼,就可以刷新瀏覽器看到效果,大大提升了開(kāi)發(fā)效率。
總結(jié)
以上是生活随笔為你收集整理的Python学习笔记:Day13 提升开发效率的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: vaex 处理海量数据_Vaex真香!几
- 下一篇: Python进阶_wxpy学习:机器人对