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的Pyspider为例剖析搜索引擎的网络爬虫实现方法
Mar 30 Python
python抓取最新博客内容并生成Rss
May 17 Python
21行Python代码实现拼写检查器
Jan 25 Python
Python3实现并发检验代理池地址的方法
Sep 18 Python
Python实现注册登录系统
Aug 08 Python
Python使用Turtle模块绘制五星红旗代码示例
Dec 11 Python
python3 判断列表是一个空列表的方法
May 04 Python
在Django中输出matplotlib生成的图片方法
May 24 Python
Django项目中包含多个应用时对url的配置方法
May 30 Python
Pytest mark使用实例及原理解析
Feb 22 Python
Django+Uwsgi+Nginx如何实现生产环境部署
Jul 31 Python
利用Python pandas对Excel进行合并的方法示例
Nov 04 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使用smtp发送支持附件的邮件示例
2014/04/13 PHP
php curl 获取https请求的2种方法
2015/04/27 PHP
Yii清理缓存的方法
2016/01/06 PHP
php远程下载类分享
2016/04/13 PHP
PHP实现的登录,注册及密码修改功能分析
2016/11/25 PHP
thinkPHP5 tablib标签库自定义方法详解
2017/05/10 PHP
确保Laravel网站不会被嵌入到其他站点中的方法
2019/10/18 PHP
防止页面被iframe(兼容IE,Firefox火狐)
2010/07/04 Javascript
理解JavaScript事件对象
2016/01/25 Javascript
基于Jquery插件实现跨域异步上传文件功能
2016/04/26 Javascript
JavaScript中使用webuploader实现上传视频功能(demo)
2017/04/10 Javascript
Vue上传组件vue Simple Uploader的用法示例
2017/08/25 Javascript
利用JS动态生成隔行换色HTML表格的两种方法
2018/10/09 Javascript
es6基础学习之解构赋值
2018/12/10 Javascript
每天学点Vue源码之vm.$mount挂载函数
2019/03/11 Javascript
JS实现可切换图片的幻灯切换效果示例
2019/05/24 Javascript
jQuery实现电梯导航模块
2020/12/22 jQuery
Python使用PyCrypto实现AES加密功能示例
2017/05/22 Python
Python实现账号密码输错三次即锁定功能简单示例
2019/03/29 Python
python使用MQTT给硬件传输图片的实现方法
2019/05/05 Python
Python re 模块findall() 函数返回值展现方式解析
2019/08/09 Python
python多进程并发demo实例解析
2019/12/13 Python
Python3 socket即时通讯脚本实现代码实例(threading多线程)
2020/06/01 Python
Python常用base64 md5 aes des crc32加密解密方法汇总
2020/11/06 Python
python中用ctypes模拟点击的实例讲解
2020/11/26 Python
在HTML5 canvas里用卷积核进行图像处理的方法
2018/05/02 HTML / CSS
努比亚手机官网:nubia
2016/10/06 全球购物
意大利辅助药品、药物和补品在线销售:FarmaEurope
2020/04/29 全球购物
一句话工作感言
2014/03/01 职场文书
食品安全责任书
2014/04/15 职场文书
工伤事故处理协议书怎么写
2014/10/15 职场文书
2014年党员个人工作总结
2014/12/02 职场文书
汽车销售合同文本
2019/08/08 职场文书
python tkinter Entry控件的焦点移动操作
2021/05/22 Python
Python连接Postgres/Mysql/Mongo数据库基本操作大全
2021/06/29 Python
JavaScript中时间格式化新思路toLocaleString()
2021/11/07 Javascript