Python3 正在毁灭 Python的原因分析


Posted in Python onNovember 28, 2014

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。人们将把它遗忘。

Python 相关文章推荐
用Python代码来绘制彭罗斯点阵的教程
Apr 03 Python
Python中is与==判断的区别
Mar 28 Python
Python数据分析之如何利用pandas查询数据示例代码
Sep 01 Python
浅谈python中的占位符
Nov 09 Python
Python基于csv模块实现读取与写入csv数据的方法
Jan 18 Python
深入flask之异步非堵塞实现代码示例
Jul 31 Python
python os.listdir按文件存取时间顺序列出目录的实例
Oct 21 Python
Python3之手动创建迭代器的实例代码
May 22 Python
使用python实现时间序列白噪声检验方式
Jun 03 Python
python跨文件使用全局变量的实现
Nov 17 Python
C站最全Python标准库总结,你想要的都在这里
Jul 03 Python
Matplotlib绘制条形图的方法你知道吗
Mar 21 Python
关于你不想知道的所有Python3 unicode特性
Nov 28 #Python
Python 2.7.x 和 3.x 版本的重要区别小结
Nov 28 #Python
用Python编写一个国际象棋AI程序
Nov 28 #Python
Python中给List添加元素的4种方法分享
Nov 28 #Python
Python列表(list)、字典(dict)、字符串(string)基本操作小结
Nov 28 #Python
跟老齐学Python之使用Python查询更新数据库
Nov 25 #Python
跟老齐学Python之使用Python操作数据库(1)
Nov 25 #Python
You might like
用cookies来跟踪识别用户
2006/10/09 PHP
解析PHP的session过期设置
2013/06/29 PHP
PHP魔术方法之__call与__callStatic使用方法
2017/07/23 PHP
一个JavaScript的求爱小特效
2014/05/09 Javascript
JS中如何判断传过来的JSON数据中是否存在某字段
2014/08/18 Javascript
js实现touch移动触屏滑动事件
2015/04/17 Javascript
jQuery实现类似标签风格的导航菜单效果代码
2015/08/25 Javascript
JavaScript中的ajax功能的概念和示例详解
2016/10/17 Javascript
canvas实现图片根据滑块放大缩小效果
2017/02/24 Javascript
jQuery实现基本隐藏与显示效果的方法详解
2018/09/05 jQuery
vue-router 前端路由之路由传值的方式详解
2019/04/30 Javascript
nodemon实现Typescript项目热更新的示例代码
2019/11/19 Javascript
原生JS实现烟花效果
2020/03/10 Javascript
vue axios封装httpjs,接口公用配置拦截操作
2020/08/11 Javascript
Python实现的金山快盘的签到程序
2013/01/17 Python
jupyter notebook引用from pyecharts.charts import Bar运行报错
2020/04/23 Python
pyqt5 lineEdit设置密码隐藏,删除lineEdit已输入的内容等属性方法
2019/06/24 Python
python爬虫 猫眼电影和电影天堂数据csv和mysql存储过程解析
2019/09/05 Python
详解Python 中sys.stdin.readline()的用法
2019/09/12 Python
python tkinter canvas使用实例
2019/11/04 Python
Python自动采集微信联系人的实现示例
2020/02/28 Python
python3.6中anaconda安装sklearn踩坑实录
2020/07/28 Python
分布式全文检索引擎ElasticSearch原理及使用实例
2020/11/14 Python
canvas实现扭蛋机动画效果的示例代码
2018/10/17 HTML / CSS
LODI女鞋在线商店:阿利坎特的鞋类品牌
2019/02/15 全球购物
eBay英国购物网站:eBay.co.uk
2019/06/19 全球购物
Java语言程序设计测试题选择题部分
2014/04/03 面试题
优秀员工年终发言演讲稿
2014/01/01 职场文书
小学三年级学生评语
2014/04/22 职场文书
办公室主任岗位承诺书
2014/05/29 职场文书
婚庆答谢词
2015/01/04 职场文书
交警失职检讨书
2015/01/26 职场文书
《小摄影师》教学反思
2016/02/18 职场文书
自己搭建resnet18网络并加载torchvision自带权重的操作
2021/05/13 Python
详解MySQL集群搭建
2021/05/26 MySQL
MySQL窗口函数的具体使用
2021/11/17 MySQL