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 相关文章推荐
Linux下使用python调用top命令获得CPU利用率
Mar 10 Python
Python 基础教程之包和类的用法
Feb 23 Python
python获取外网IP并发邮件的实现方法
Oct 01 Python
深入理解Python分布式爬虫原理
Nov 23 Python
基于python实现在excel中读取与生成随机数写入excel中
Jan 04 Python
python3第三方爬虫库BeautifulSoup4安装教程
Jun 19 Python
python3实现点餐系统
Jan 24 Python
python利用tkinter实现屏保
Jul 30 Python
python不使用for计算两组、多个矩形两两间的iou方式
Jan 18 Python
python-sys.stdout作为默认函数参数的实现
Feb 21 Python
python GUI模拟实现计算器
Jun 22 Python
python opencv角点检测连线功能的实现代码
Nov 24 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
推荐几部必看的DC动画电影
2020/03/03 欧美动漫
php检测图片木马多进制编程实践
2013/04/11 PHP
Android ProgressBar进度条和ProgressDialog进度框的展示DEMO
2013/06/19 PHP
PHP pthreads v3下同步处理synchronized用法示例
2020/02/21 PHP
PHP中->和=>的含义及使用示例解析
2020/08/06 PHP
js常用函数 不错
2006/09/08 Javascript
JavaScript的单例模式 (singleton in Javascript)
2010/06/11 Javascript
了解Javascript的模块化开发
2015/03/02 Javascript
Node.js+Express配置入门教程详解
2016/05/19 Javascript
基于ajax与msmq技术的消息推送功能实现代码
2016/12/26 Javascript
深入理解Commonjs规范及Node模块实现
2017/05/17 Javascript
vue-router实现webApp切换页面动画效果代码
2017/05/25 Javascript
通俗解释JavaScript正则表达式快速记忆
2017/08/23 Javascript
React 高阶组件入门介绍
2018/01/11 Javascript
electron中使用bootstrap的示例代码
2018/11/06 Javascript
vue实现信息管理系统
2020/05/30 Javascript
Vue $emit()不能触发父组件方法的原因及解决
2020/07/28 Javascript
Vue.js中使用Vuex实现组件数据共享案例
2020/07/31 Javascript
[01:06]DOTA2小知识课堂 Ep.01 TP出门不要忘记帮队友灌瓶哦
2019/12/05 DOTA
Python的Django框架可适配的各种数据库介绍
2015/07/15 Python
python算法表示概念扫盲教程
2017/04/13 Python
Python实现的列表排序、反转操作示例
2019/03/13 Python
python实现简单聊天室功能 可以私聊
2019/07/12 Python
python模块导入的方法
2019/10/24 Python
Python3实现mysql连接和数据框的形成(实例代码)
2020/01/17 Python
Python中读取文件名中的数字的实例详解
2020/12/25 Python
美国正版电视节目和电影在线观看:Hulu
2018/05/24 全球购物
电子商务毕业生求职信
2013/11/10 职场文书
爱我中华教学反思
2014/04/28 职场文书
大四学生个人总结
2015/02/15 职场文书
酒店工程部经理岗位职责
2015/04/09 职场文书
2015年药品销售工作总结范文
2015/05/25 职场文书
党纪处分决定书
2015/06/24 职场文书
2015最新民情日记范文
2015/06/26 职场文书
总结Python变量的相关知识
2021/06/28 Python
SpringBoot整合Redis入门之缓存数据的方法
2021/11/17 Redis