爲 Sublime Text 3 設置 Python 的全棧開發環境css
Sublime Text 3 (ST3) 是一個輕量級的跨平臺文字編輯器,尤以其輕快的速度,易用性和強大的社區支持而著稱。它一經面世便被認爲是一個傑出的編輯器,而它真正的強大之處在於你可使用 Package Control 來增長它的功能以及能夠進行各類自定義設置。html
在本文章中,咱們將會看到如何將 Sublime Text 打形成爲 Python 的全棧開發環境(從前端到後端),如何經過自定義主題和插件來加強它的基本功能,而且還將會涉及到不少使 ST3 變得更增強大的經常使用的命令,特性以及快捷鍵。前端
本教程將假定你使用的是 Mac 電腦而且習慣於使用終端。若是你使用的是 Windows 或者 Linux 操做系統,本文涉及到的一些命令將有可能會有所不一樣,可是你應該仍然能夠很容易地經過 Google 來獲取到與本教程相關的解答。python
在咱們開始以前,讓咱們先討論一下我所謂的」全棧」具體指的是什麼。git
在如今的 HTML5 以及移動設備開發中,Javascript 簡直無處不在。是的,無處不在!僅僅使用 Python 基於某個框架好比 Django 或者 Flask 進行開發是不夠的。若是你想從始至終真正的本身開發一個網站的話,你必須熟悉 Javascript(以及 Javascript 的一大堆的框架),REST API(含狀態傳輸 API),響應式設計,固然還有 HTML 和 CSS,以及其餘許多東西。如今讓咱們來面對一個問題:就像其餘任何一個手藝人同樣,爲了成爲一個最厲害的程序員,你的工具必須犀利,你的開發環境必須被打形成全棧開發——那就是咱們立刻將要開始的工做…程序員
讓咱們從 ST3 的一些默認特性開始着手吧…github
同時,你還能夠點擊 Tools > New Snippet 來建立屬於你本身的代碼片。請參照這個 文檔來獲取幫助,也能夠在 這裏 查看我我的用到的一些 snippets。web
在你下載完 ST3 之後…編程
subl
命令就像 TextMate 的 mate
命令同樣,Sublime Text 擁有一個叫作 subl
的命令行工具,能夠用來經過終端打開一個文件或者一整個文件夾。json
你須要創建一個指向 subl 二進制文件的符號連接來使 subl 命令有效:
Python
1 |
$ ln -s "/Applications/Sublime Text.app/Contents/SharedSupport/bin/subl" ~/bin/subl |
嘗試使用如下命令來打開 Sublime 來確保連接生效了:
Python
1 |
$ subl |
若是以上命令沒有效果,你可能須要將 /bin 添加到你的環境變量中:
Python
1 |
$ echo "export PATH=~/bin:$PATH" >> ~/.profile |
而後從新嘗試第一步。
若是你仍然遇到問題,嘗試查看 這篇 文章來獲取幫助。 或者你能夠看看如何在 Windows和 Linux 中創建符號連接。
如今你就能夠經過下述命令來打開文件或者文件夾了:
Python
1 2 3 4 5 6 7 8 |
# open the current directory $ subl .
# open a directory called tests $ subl ~/Documents/test
# open a file called text.txt $ subl test.txt |
若是路徑中含有空格,你必須使用雙引號將路徑括起來:
Python
1 |
$ subl "~/Documents/test/my test file.txt" |
想要查詢全部可用的命令,請打開幫助文件:
Python
1 |
$ subl --help |
爲了使用衆多的 插件 來擴展 Sublime 的功能,你須要安裝一個叫作 Package Control 的插件管理器——這個東西你必需要手動安裝。可是一旦你安裝好了之後,你就可使用 Package Control 來安裝,移除或者升級全部的 ST3 插件了。
請查閱官方 文檔 獲取更多的命令。
你能夠經過一個基於 JSON 的配置文件來充分的自定義 Sublime Text,這使得轉移或者同步你的自定義文件到另外一個系統變得很是容易。首先,咱們須要新建咱們本身的配置文件。咱們最好是爲不一樣的系統環境和編程語言各自建立一個配置文件。
依次點擊 Sublime Text > Preferences > Settings – User 來建立一個配置文件。在該文件中添加一個空的 JSON 類而後就能夠在其中寫入你的配置內容了。以下所示:
Python
1 2 3 4 5 6 7 |
{ // base settings "auto_complete": false, "sublimelinter": false, "tab_size": 2, "word_wrap": true } |
ST3 爲你提供了徹底自定義化一個適合本身主題的能力。固然,你若是不是那麼的挑剔的話,你能夠經過 Package Control 從許許多多的由 Sublime 社區設計的 主題 中下載一個。 在下載以前你能夠經過 ColorSublime 來預覽這些主題。
廣受歡迎的的 Soda Dark 和極簡風格的 Flatland 是我我的最喜歡的兩個主題。
在安裝完了主題之後, 請務必更新你的配置文件. Sublime Text > Preferences > Settings – User:
Python
1 2 3 4 |
{ "theme": "Flatland Dark.sublime-theme", "color_scheme": "Packages/Theme - Flatland/Flatland Dark.tmTheme" } |
除了那些主題之外,我還會使用如下這一些插件來提高個人工做效率。
SideBarEnhancements 擴展了側邊欄中菜單選項的數量,從而提高你的工做效率。諸如」New file」 和 「Duplicate」 這樣的選項對於 ST3 來講實在是過重要了, 我甚至以爲 ST3 原本就應該提供這些功能。並且僅憑 「Delete」 這一個功能就讓這個插件值得下載。這個功能將你會在你刪除文件的時候把它放入回收站。雖然這個功能乍一看沒什麼用,可是當你沒有使用這樣的功能而完全刪除了一個文件的時候,除非你用了版本管理軟件,不然你將很難恢復這個文件。
如今就下載吧!
Anaconda 是一個終極 Python 插件。它爲 ST3 增添了多項 IDE 相似的功能,例如:
{"anaconda_linting": false}
你能夠在這裏,或者經過 ST3 的 Package Settings: Sublime Text > Preferences > Package Settings > Anaconda > README 來查看全部這些特性。
SublimeCodeIntel 是另一個很是流行的插件,它的許多特性與 Anaconda 相似。我建議同時也試試它。
Djaneiro 支持 Django 模版和關鍵字高亮以及許多實用的代碼片(snippets)功能。其中的 snippets 絕對是省時神器。你能夠經過不多幾個關鍵字就能建立許多常見的 Django 代碼塊好比 templates,models,forms,以及 views。請查看官方文檔獲取 snippets 列表。
我我的很是喜歡的如下兩個用於建立 template 的代碼片:輸入 var
就能夠新建 {{ }}
,而輸入 tag
就能新建 {% %}
。
Requirementstxt 能夠爲你的 requirements.txt 文件提供自動補全,語法高亮以及版本管理功能。
SublimeLinter 是 ST3 的一個代碼靜態檢查工具框架(linter)。這個插件自己來講並不包含任何的一個 linter,可是你能夠經過在 Package Control 中輸入 SublimeLinter-[linter_name] 的方式來安裝一個 linter。你能夠點擊這裏查看官方的 linter。同時你還能夠在 Package Control 中查看到許多的第三方 linter。請點擊這裏查看安裝說明。
對於 Python 的代碼靜態檢查器,我建議使用 SublimeLinter-pyflakes 和 SublimeLinter-pep8。
與此同時,我也會使用 SublimeLinter-jshint, SublimeLinter-pyyaml, SublimeLinter-csslint,SublimeLinter-html-tidy,以及 SublimeLinter-json。
以上大多數的 linter 都須要先安裝一些依賴庫才能使用,因此在安裝前請務必閱讀他們的安裝說明。
你能夠經過修改用戶自定義的 SublimeLinter.sublime-settings 文件來對你的每一個 linter 個性化:Sublime Text > Preferences > Package Settings > SublimeLinter > Settings – User. 例如我經過如下代碼來忽略 pep8 中的錯誤和警告:
Python
1 2 3 4 5 6 7 8 |
"pep8": { "@disable": false, "args": [], "excludes": [], "ignore": "E501,C0301,W0142,W0402,R0201,E1101,E1102,C0103,R0901,R0903,R0904,C1001,W0223,W0232,W0201,E1103,R0801,C0111", "max-line-length": 100, "select": "" }, |
GitGutter 讓 ST3 能在左邊欄的位置顯示一個小圖標,用以表示在最後一次提交之後,代碼是否有追加,修改或者刪除。
若是你想讓該插件支持分佈式的版本管理軟件(Git,SVN,Bazaar 和 Mercurial)。請查看Modific。
FTPSync 可以將你的項目和遠程文件進行同步。你只須要打開文件即可如下載更新(若是你的遠端文件比本地更加新的話),並且若是你對本地文件作出了修改能夠當即同步到遠程服務器。這是很是棒的同步本地文件和遠程文件的方法。你能夠經過如下的方法來添加你的遠程服務器:Sublime Text > Preferences > Package Settings > FTPSync > Setup FTPSync.
Sample settings:
Python
1 2 3 4 5 6 7 8 9 10 11 |
{ 'primary': { host: 'ftp.mywebsite.com', username: 'johnsmith', password: 'secretpassword', path: '/www/',
upload_on_save: true, tls: true } } |
我我的喜歡把密碼設爲 null
由於我不想讓個人密碼出如今配置文件中。這樣 FTPSync 會在我每次保存完文件後要求我輸入密碼。
AdvancedNewFile 可讓你在 ST3 中使用簡單的幾個快捷鍵便建立一個新的文件夾或者一個新的文件:
你只須要經過幾個快捷鍵即可以打開 AdvancedNewFile 的輸入框。而後輸入路徑和文件名。當你按下回車鍵後,文件便被建立了。除此以外,若是目標文件夾並不存在的話,該文件夾將會被自動創建。在默認狀況下,你建立的文件的路徑將會顯示在狀態欄中。
請查看 Github 上的這篇文檔來獲取更爲詳細的使用說明。特別建議請詳細閱讀TAB自動補全(Tab Completion)以及預約義別名(Predefined Aliases)部分。
我把「cmd+n」設置爲了經過 AdvancedNewFile 建立新文件的快捷方式。該快捷鍵能夠經過修改 Key Bindings – User file 來實現 Sublime Text > Preferences > Package Settings > AdvancedNewFile > Key Bindings – User:
Python
1 2 3 |
[ { "keys": ["cmd+n"], "command": "advanced_new_file_new"} ] |
你也能夠更改默認打開的文件夾路徑:Sublime Text > Preferences > Package Settings > AdvancedNewFile > Settings – User
Python
1 |
{"default_initial": "/Users/michaelherman/Documents/repos"} |
這樣我建立新文件的時候,/Users/michaelherman/Documents/repos
將會自動被添加到路徑最前方,由於99%的狀況下我都會把個人腳本放在這個路徑下。
Emmet,之前叫作 Zen Coding,讓你能夠經過簡單的縮寫來建立 HTML 或者 CSS 的代碼塊。
例如,你只須要輸入感嘆號!
,而後按下 tab 鍵,即可以在一個 HTML 文件中建立一段帶有幾個基本標籤的 HTML5 文檔類型的代碼:
Python
1 2 3 4 5 6 7 8 9 10 |
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body>
</body> </html> |
Markdown Preview 能夠用來預覽和編譯 markdown 文件。
你能夠打開 Package Manager 而後輸入 Markdown Preview 來查看可用的命令:
一旦你完成轉換,你以後的全部保存都會當即反映到轉換的文件中。
Python
1 2 |
1.選定一個單詞,點擊 **「cmd+d」** 來選擇一樣的單詞,再次點擊 **「cmd+d」** 繼續選擇下一個單詞… 2.或者 **「cmd+單擊」** 來指定多個你想要同時修改的地方。 |
若是想了解更多關於快捷鍵的內容,請看一下這篇文章。
你能夠很容易地使用 Python 來編輯你本身的自定義命令和快捷鍵組合。目前我我的使用的有如下這些:
經過文件選項打開你的 Package 文件夾(Sublime > Preferences > Browse Packages),而後打開 User 文件夾,接下來將上述的 Python 文件添加到 「/Sublime Text 3/Packages/User」 文件夾中。最後請在 Key Bindings – User file (Sublime Text > Preferences > Package Settings > AdvancedNewFile > Key Bindings – User) 文件中完成快捷鍵綁定。
Python
1 2 3 4 5 6 7 8 9 10 11 12 |
[ // Copy file name { "keys": ["cmd+shift+c"], "command": "copy_path_to_clipboard" }, // Close all other tabs { "keys": ["cmd+alt+w"], "command": "close_tabs" } ] |