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查询阿里巴巴关键字排名的方法
Jul 08 Python
Python3+django2.0+apache2+ubuntu14部署网站上线的方法
Jul 07 Python
Anaconda2 5.2.0安装使用图文教程
Sep 19 Python
python自动化生成IOS的图标
Nov 13 Python
Python http接口自动化测试框架实现方法示例
Dec 06 Python
python:按行读入,排序然后输出的方法
Jul 20 Python
python redis连接 有序集合去重的代码
Aug 04 Python
关于numpy中eye和identity的区别详解
Nov 29 Python
在pytorch中动态调整优化器的学习率方式
Jun 24 Python
Python return语句如何实现结果返回调用
Oct 15 Python
在pyCharm中下载第三方库的方法
Apr 18 Python
Python内置的数据类型及使用方法
Apr 13 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
php通过array_unshift函数添加多个变量到数组前端的方法
2015/03/18 PHP
Laravel 解决419错误 -ajax请求错误的问题(CSRF验证)
2019/10/25 PHP
javascript中的几个运算符
2007/06/29 Javascript
一段利用WSH修改和查看IP配置的代码
2008/05/11 Javascript
ASP.NET jQuery 实例1(在TextBox里面创建一个默认提示)
2012/01/13 Javascript
jquery获取对象的方法足以应付常见的各种类型的对象
2014/05/14 Javascript
JavaScript判断字符长度、数字、Email、电话等常用判断函数分享
2015/04/01 Javascript
JS实现字符串转日期并比较大小实例分析
2015/12/09 Javascript
JS函数定义方式的区别介绍
2016/03/22 Javascript
解析JavaScript数组方法reduce
2016/12/12 Javascript
jQuery实现鼠标响应式透明度渐变动画效果示例
2018/02/13 jQuery
Vue.js获取被选择的option的value和text值方法
2018/08/24 Javascript
vue中axios请求的封装实例代码
2019/03/23 Javascript
JS实现横向跑马灯效果代码
2020/04/20 Javascript
webpack+vue.js构建前端工程化的详细教程
2020/05/10 Javascript
AngularJs的$http发送POST请求,php无法接收Post的数据问题及解决方案
2020/08/13 Javascript
CentOS中使用virtualenv搭建python3环境
2015/06/08 Python
python 读取摄像头数据并保存的实例
2018/08/03 Python
解决sublime+python3无法输出中文的问题
2018/12/12 Python
Django 全局的static和templates的使用详解
2019/07/19 Python
Python在cmd上打印彩色文字实现过程详解
2019/08/07 Python
详解python实现可视化的MD5、sha256哈希加密小工具
2020/09/14 Python
python os.listdir()乱码解决方案
2021/01/31 Python
h5页面背景图很长要有滚动条滑动效果的实现
2021/01/27 HTML / CSS
How TDD works
2012/09/30 面试题
广告学专业毕业生自荐信
2014/05/28 职场文书
交通事故死亡赔偿协议书
2014/12/03 职场文书
银行求职自荐信范文
2015/03/04 职场文书
教师党员自我评价2015
2015/03/04 职场文书
2015年全国保险公众宣传日活动方案
2015/05/06 职场文书
2015年防汛工作总结
2015/05/15 职场文书
八年级物理教学反思
2016/02/19 职场文书
python中pandas对多列进行分组统计的实现
2021/06/18 Python
PostgreSQL解析URL的方法
2021/08/02 PostgreSQL
Golang日志包的使用
2022/04/20 Golang
SQL Server使用CROSS APPLY与OUTER APPLY实现连接查询
2022/05/25 SQL Server