Windows 10中使用Python碰到的奇怪現(xiàn)象
最近在使用 Python 的時候發(fā)生了很奇怪的現(xiàn)象:從命令行執(zhí)行 python.exe 并不會進(jìn)入 REPL,似乎也沒有其他反應(yīng),然而稍等片刻,會看到系統(tǒng)彈出 Windows Store 頁面,并定位到 Python App 的詳情頁。
這個現(xiàn)象讓我很是迷惑了一下,還以為是 Python 運行環(huán)境出了什么狀況,但很快反應(yīng)過來,從現(xiàn)象看,應(yīng)該是 Windows 搞的鬼。
檢查一下路徑是否正常,果然:
- \$ where python
- C:\\Users\\yuhao\\AppData\\Local\\Microsoft\\WindowsApps\\python.exe
原理是系統(tǒng)自己搞了一個 Python.exe。如果從在資源管理器打開上述目錄的話,會看到這里只有孤零零的幾個 .exe 文件,且圖標(biāo)也不正常,并不是一個真正的、完整的 Python 運行環(huán)境。
那么問題來了,Windows 搞這些沒有實際環(huán)境的 .exe 出來,用意何在?
從網(wǎng)上找到一些信息,原來從 Windows 10 2019 五月更新以來,微軟試圖把 Python 帶到 Windows,至于具體做法,則是把 Python3 放到了自家的商店里面。而上面看到的 python.exe 是一個“假的” Python,它的唯一作用在于當(dāng)系統(tǒng)沒有找到 Python 的時候,自動跳轉(zhuǎn)到微軟商店去讓我們下載。
以下是微軟團(tuán)隊給出的說法:Who put Python in the Windows 10 May 2019 Update?
可能是擔(dān)心這個新的功能導(dǎo)致一些兼容性方面的結(jié)果,微軟又在系統(tǒng)設(shè)置里面添加了一個比較隱晦的功能。比起在層層疊疊的設(shè)置界面里找到它,更簡單的方法是直接輸入 app exec:
這樣會打開設(shè)置的“應(yīng)用程序別名”界面。這里我們會看到系統(tǒng)認(rèn)為 python.exe 和 python3.exe 都只是安裝程序的別稱,不過我們也可以選擇把它們關(guān)閉。這樣當(dāng)我們再運行 python 的時候,就會顯示“找不到程序”的標(biāo)準(zhǔn)提示。實際上,Windows 是把上述 .exe 文件偷偷備份到其他地方了。
很多程序員(包括我)很可能都是按照標(biāo)準(zhǔn)的方式從官方下載安裝 Python 執(zhí)行文件。如果在安裝過程中選擇了“添加到系統(tǒng)環(huán)境變量”的話,那么標(biāo)準(zhǔn) Python 會注冊到系統(tǒng) PATH 變量,而前面所述的 WindowsApps 目錄則是 Windows 添加到用戶 PATH 變量的。按照 Windows 系統(tǒng)的規(guī)則,PATH 環(huán)境變量是系統(tǒng)設(shè)置先于用戶設(shè)置,所以如果安裝了標(biāo)準(zhǔn)版 Python 的話,系統(tǒng)應(yīng)該首先找到的是它,而不是應(yīng)用商店版的 Python。后來我發(fā)現(xiàn),之所以我的機(jī)器會出現(xiàn)上述問題,是因為系統(tǒng)設(shè)置有一點語法錯誤,修正以后再次測試,結(jié)果就正常了。
到此,我們已經(jīng)理解了 Windows 自帶的 Python 是怎么回事。微軟這樣做的初衷,應(yīng)該是希望普通用戶能更方便地用上 Python,這個想法無可厚非,但放到 Windows 應(yīng)用商店這個設(shè)計思路是否合理,我還是有一些懷疑的。畢竟微軟應(yīng)用商店一直以來名聲并不算太好,內(nèi)容少、功能欠缺、速度慢,時不時發(fā)生一些惱人的小問題(比如 不知所云的 0x8000xxxx 錯誤)。而“應(yīng)用程序別名”這個功能到底是解決了問題還是帶來更多的困惑,我也持保留意見。
當(dāng)我在網(wǎng)上查找關(guān)于該問題的信息時,也發(fā)現(xiàn)有其他用戶同樣受到該問題的困擾,比如:
- [Bug] Don't find python library from WindowsApps dir
- Microsoft Store installed python (3.7 - Windows 10) based virtualenvs cannot access pyd DLLs
目前,在 Windows 上面安裝 Python 已經(jīng)有很多不同的方式:
- 通過官方網(wǎng)站下載安裝;
- 通過 Anaconda 集成軟件包;
- 和 Visual Studio 一起安裝;
- 通過 chocolatey 之類的第三方包管理;
- 通過 WSL 安裝 Linux 版 Python;
- 通過 Windows Store 安裝;
說實話,我認(rèn)為太多不同的來源渠道會讓環(huán)境問題變得更復(fù)雜,增加出錯的可能,并且容易迷惑初學(xué)者。對于大多數(shù)程序員來說,建議大家還是按照最基本的方式,從官方下載并安裝 Python。