解密:Python风靡全宇宙,首要原因竟是它?

简介:

众所周知,Python是目前使用最广泛且用户增长最快的编程语言。优雅简洁的语法、强大的第三方库支持等都是Python能够风靡各行各业的原因。然而,你或许不知道,Python能够实现用户飞速增长,背后其实另有玄机。

就让我们从近年来大数据的兴起说起,为你娓娓道来Python火爆的真正原因。

郁闷的大数据程序员

随着大数据的崛起,大多数行业发现自己进入了一种恐慌状态:他们花费了大量的时间和金钱来建立他们的大数据渠道,但是他们的投资回报率却很低。在毫无喘息机会的竞争中,虽然能够挖取到日益增长的数据,但大多数公司并没有一个明确的计划来处理他们挖取到的数据。当时,几乎每个人都认为,有了大量的数据存储,后面的分析就会变得更简单,数据的业务价值也会变得显而易见。这在今天听起来可能很愚蠢,但大多数人依旧认为,只要获取到足够的数据,数据背后的规律和信息就会自动浮现。

被时代召唤的“数据科学家”

随后,业界几乎同时觉醒,他们希望得到的各种卓越远见和希望回答的问题都需要严格的数学分析和验证。 SQL查询能让你知道数据最明显的模式和趋势,但要想获取数据中最为有用的信息,你需要的其实是完全不同的另一套技术——一套牢固扎根于数学和应用数学的技能。而具备这种技术的人才似乎只存在于学术界中。此外,负责分析这些庞大数据集的人不仅需要非常强大的数学背景,还需要能够编写软件。这也不难解释为什么“数据科学家”这一职位频繁出现在招聘网站上了。

Ruby与Python的“Web开发语言之争”

我们再往回讲讲,在大数据还没有真正风靡之前,Ruby和Python曾在成为最受欢迎的“web开发语言”上发生过激烈的争战。 两者都非常适合开发Web应用程序。 Ruby的受欢迎程度与Rails框架密切相关。 在那个年代,大多数自称为“Ruby程序员”其实更应该称自己为 “Rails程序员”。 而Python在学术界和少数不同行业已经相当完善。 在Python中,与Rails最相近的是Django,Django尽管在Rails之前发布,但它的受欢迎程度似乎远远落后于Rails。

很多人认为,Python和Ruby的性能都很相似,最终只会有一种语言能够赢得“web开发语言之战”。 但实际上,Ruby的流行度与Rails密切相关,而Django只代表了一个已经很活跃的Python生态系统的一小部分。事实也证明,“Web开发语言之战”的重要性远低于人们的预期。即便从很多层面来讲,Ruby都凭借Rails赢得了这场争战,但这丝毫不影响Python成为当今最受欢迎的语言。这到底是为什么呢?

Oliphant的大手笔

为了揭开这个谜团,我们就不得不提一下一位大佬了,他就是Travis Oliphant。追溯到2006年。当时,Travis Oliphant还是BYU的助理教授,他仍未创办Anaconda(注:Anaconda是一个完全以Python为基础的,目前最成功的商业数据科学平台之一)。 一年前,他参考科学计算库Numeric开发了NumPy。 他后来又成为SciPy的创始人并兼任了PSF的主管。

在2006年,他与Carl Banks一起提交了PEP 3118,这是Python的“缓冲区协议”的修订版。这为Python的兴起埋下了重要伏笔。

Python的缓冲协议:Python风靡全球的首要原因

缓冲器协议是(并且仍然是)一个极低级别的API,被其他库用来直接操纵内存缓冲区。 这些是由解释器创建和使用的缓冲器,用于存储连续存储器中某些类型的数据(最初,主要是“类似数组的”数据类型和大小都被提前给出的数据结构)。

提供这样一个API的主要动机是:消除在只读取时复制数据的必要性,澄清缓冲区的所有权转移语意,并将数据存储在连续的存储器中(即使在多维数据结构的情况下),其中读取访问速度非常快。 那些将使用该API的“其他库”一般都是用C写的,而且对性能十分敏感。 这一新协议意味着,如果我创建了一个NumPy的int数组,其他库可以直接访问底层内存缓冲区,而不是间接访问或者在使用该数据之前复制该数据。

现在问题来了:什么类型的程序员会从快速、零拷贝的大量数据获取中受益呢?

当然是数据科学家了!

让我们们来梳理一下事件的发展过程:

  • Oliphant和Banks提出了Python的缓冲协议的修订,以简化对刚开始的NumPy项目工作所驱动的某些数据结构的底层内存的直接访问。
  •  PEP 3118(https://www.python.org/dev/peps/pep-3118/) 提交,被认可,实施。
  • 受益于PEP 3118的实现,Python已悄然成为一个非常吸引人的编译语言。在此基础上,就有了很多基于C语言扩展的数字计算库被开发出来(注:C语言扩展可以很便捷地实现数据共享和操作。)
  • Python和Ruby在网络上一决雌雄,大多数人认为“Web开发语言之战”必有分晓。
  • 随着磁存储设备价格暴跌,存储大量数据以供日后分析变得可行(因为数据已经变得很廉价,最好是先把数据保存起来,甚至都不需要去考虑具体要分析什么。)
  • 对新一代程序员的需求发生变化:具有统计学背景,最好还得有应用数学背景的,且先前有过一些编程经验的程序员开始被哄抢——数据科学家的时代来临了!
  • 数据科学家们想寻找一种既具有表现力又快速的语言(具有良好的数值计算库支持启动),所有的这些需求都指向于Python后来,就如我们看到的那样,Python受到万千宠爱,一跃成为了最受欢迎的编程语言。
原文发布时间为:2017-10-25
本文作者:吴蕾、霍静
本文来自云栖社区合作伙伴“ 大数据文摘”,了解相关信息可以关注“ 大数据文摘”微信公众号
相关实践学习
基于MaxCompute的热门话题分析
Apsara Clouder大数据专项技能认证配套课程:基于MaxCompute的热门话题分析
相关文章
|
Python
Python3,5句话实现自动接收短信提醒
Python3,5句话实现自动接收短信提醒
675 0
Python3,5句话实现自动接收短信提醒
|
缓存 资源调度 JavaScript
nodejs全局(npm、cnpm、yarn)及缓存基本配置,一篇就搞定
nodejs全局(npm、cnpm、yarn)及缓存基本配置,一篇就搞定
|
存储 SQL 分布式计算
数据存储与管理技术有哪些?
数据存储与管理技术有哪些?
551 60
|
10月前
|
自然语言处理 API 开发者
DeepSeek-Free-API:DeepSeekV3免费的api接口,需要使用api方式的同学可以参考一下这个项目,可以收藏起来试一下
嗨,大家好,我是小华同学。今天为大家介绍一个开源项目——DeepSeek V3 Free 服务。该项目基于 DeepSeek-V3 R1 大模型,提供免费、高性能的 API,支持高速流式输出、多轮对话、联网搜索和深度思考等功能。适用于智能客服、内容创作、教育辅助等场景。部署方式灵活,支持 Docker、Docker-compose、Render、Vercel 和原生部署。欢迎关注我们,获取更多优质开源项目和高效工作学习方法。
2731 15
|
9月前
|
机器学习/深度学习 人工智能 运维
机器学习+自动化运维:让服务器自己修Bug,运维变轻松!
机器学习+自动化运维:让服务器自己修Bug,运维变轻松!
403 14
|
人工智能 搜索推荐 数据挖掘
销售易VS纷享销客:深入剖析两款CRM系统的优势与适用场景
销售易是国内领先的企业级CRM解决方案提供商,专注于B2B领域,提供销售管理、客户服务、营销自动化等全面支持。其核心优势包括本土化服务、技术创新、产品功能完备等,尤其适合中大型企业和特定行业如制造、高科技等。系统通过AI赋能、移动办公支持和开放平台特性,为企业带来高效、智能的管理体验。尽管价格较高,但其深度功能和扩展性使其成为复杂业务需求的理想选择。
【单片机】简易计算器完整代码带电路图
【单片机】简易计算器完整代码带电路图
1017 0
【单片机】简易计算器完整代码带电路图
|
算法 安全 关系型数据库
非对称加密算法Diffie-Hellman算法
Diffie-Hellman算法是一种非对称加密方法,用于在不安全的通道上建立共享密钥。它基于两个用户交换公开的p和g(大素数和其原根)以及各自的随机数计算得出相同的秘密密钥s/s'。算法的安全性依赖于离散对数问题的困难性,防止未授权者计算出密钥。该算法与对称加密(如AES)结合,先生成共享密钥,再用于加密实际通信,确保消息安全。
520 2
|
存储 前端开发 搜索推荐
​开源在线生成简历器:快速打造个人的简历利器
​开源在线生成简历器:快速打造个人的简历利器
665 0
|
测试技术 Shell Docker
给一个正在运行的Docker容器动态添加Volume
给一个正在运行的Docker容器动态添加Volume本文转自:http://dockone.io/article/149 【编者的话】之前有人问我Docker容器启动之后还能否再挂载卷,考虑到mnt命名空间的工作原理,我一开始认为这很难实现。
4245 0