Python 3 正在毀滅 Python

奇風餘谷發表於2014-06-02

Python 3毫不費力地成為發生在Python社群裡最糟糕的事。我還記得第一次使用Python的時候,我還在花大量時間在C++這塊上,而Python就像是我的一次開光。我可以開啟文字編輯器用幾秒鐘或者幾分鐘寫出一個可以工作的程式,而不是用幾小時或幾天。我記得Python 2.5出來的時候,帶來了一大堆嶄新的簡潔的語言特性。我愛Python,但是我承認它有弱點,但是沒關係,所有程式語言都有。它強大的地方使其變得有趣。Python 3相比Python 2擁有一些小小的增量的改進,但同時卻失去了很多Python 2強大的東西。

Python 2強大的一個地方是它身後巨大的第三方庫,恩,可以做任何事。Python 3沒有這個。是的,很多庫已經移植了,但是仍然有數以十倍的庫沒有移植過去,而且也不太容易。舉個例子,你需要解析X格式,而X解析起來並不簡單,它不是常見的像YAML或JSON的格式。很有可能這個為X的解析器在Python 2裡已經寫好了,但是還沒有移植到Python 3。另外,考慮到Python 2的位元組字串(str)和Python 3的位元組字串(bytes)之間的根本不同,移植起來將不會那麼容易。事實上會很難移植,並且需要一點移植技巧,像維護Python 2和Python 3的相容性那樣。因此,你有一些選擇,可以用Python 2(一個被棄用的語言)快速寫你的app,匯入一些庫(還有它們所有的依賴),可能會有十倍之長;或者可以用另外的程式語言,它也有很多第三方庫,但是不會面臨Python 2/3的問題。第二個選擇顯然不是很流行,因為不然,我們就有大量Python 3寫的app產品,然後Python 2的一大批庫會被移植過來。(譯者注:這個邏輯貌似有點問題?)這兩種都沒有發生。人們要麼繼續用Python 2寫軟體,要麼選擇另一個不自己打臉的語言。

另外一個Python 2的強大之處是用它寫的程式幾乎總是能夠不用大量修改而執行在Python的下一個版本上。如果你的公司運營在用Python 2寫的軟體上(就像很多公司那樣),移植到Python 3將會消耗大量資金,因為你的requirements檔案可能十分大,並且充斥著各種還沒有移植到Python 3的庫。沒有哪個理智的商業理由會花成百上千甚至百萬美元價值的開發時間來移植到Python 3。如果相比更便宜的話,你都可能會要求某某把他們整個程式碼庫移植到Ruby。現在如果你必須要重寫你的軟體的話,你會選擇Python 3嗎?不。

那些支援Python 2和3的比較流行的庫幾乎都只用該語言的子集,這樣在兩個平臺上就都能執行。SQLAlchemy,我喜愛的Python庫之一,它這樣做的很好。Django也如此,但是做得不那麼好。這個語言子集,我會稱之為Python X,使用起來很沒意思,需要一些奇淫技巧,並且通常沒有Python 2或者Python 3強大。把Python 2的庫移植到Python X有意思嗎?很可悲的是一點意思都沒有,因為令Python偉大的就是這些樂趣。

Python 2,很可悲,已經被棄用了。Python 3頹廢得沒人用。Python 3的改動不大。沒有帶來多少好處,但缺失去了很多。在過去的幾個月,我用Python 3構建了一些專案和服務。我沒有被它打敗。這很像用Python 2寫軟體,除了只能獲得很少的一些庫。這裡沒有什麼令人驚歎的事情。Python社群在過去的幾年本應該轉移到Python 3了,但是結果就是越來越明顯看到人們轉移到新的語言(或者重新發現的舊語言)上。這些語言有些也有很好的特性,像強大的輸入系統,模式匹配,更出色的效能,更好的多執行緒和併發,更簡單的外部函式介面(FFI),更漂亮的lambda語句等等。

一個方案是fork Python 2.7,然後繼續發展這門語言,加入一些儘量向後相容的特性,這樣那些不能移植(由於一些財政方面的約束)的Python 2應用程式可以繼續演進和改善,進而給那些投入如此多時間開發他們的公司或個人帶來價值。這才是需要去做的正確的事(事實上,如果Guido和Python社群裡其他主導人能夠官方地做這件事,而不是強迫大家fork,那會是最好的)。Python 3裡的特性可以向後移植到Python 2,然後釋出Python 2.8。那些已經花時間用純Python 3寫新的軟體的人可以使用例如3to2的工具變成與Python 2.8相容。Python 3然後就可以為了Python庫維護者們能夠用Python 2代替Python X而安靜地離去。

還有一些其他的方案,但是拯救Python 2顯然是要做的正確的事,所以也不值一提了。Python 2的拯救不會來自官方,因為負責這類事的人表現出了對Python 2使用者極大的鄙視。如果社群的人不團結起來拯救Python 2,Python 3數年之後會成為Python的標準,然後很多庫將要被移植(儘管很多肯定不會),然後很多的投入也將會白費。社群那時候會大量的萎縮,並失去往日的光芒。參考Perl。人們將把它遺忘。

相關文章