JetBrains 调研:2025 年最受欢迎的 Python 框架和库

jetbrains 调研:2025 年最受欢迎的 python 框架和库

JetBrains 从年度 Python 开发者调研中,梳理了一份有关最受欢迎的 Python 框架和库的详细信息。“尽管Django、Flask等一些长期热门工具依旧势头强劲,但FastAPI等新兴框架正迅速在 AI、机器学习和数据科学等领域占据一席之地。”

FastAPI

2024 年使用率:38%(较 2023 年增长 9%)

榜单第一位是FastAPI,这是一款适用于 Python 3.8 及以上版本,用于构建 API 的现代高性能 Web 框架。 它的设计初衷是将 Python 的类型提示、异步编程与 OpenAPI 标准整合到一个开发者友好型软件包中。

FastAPI 基于Starlette(用于 Web 层)和Pydantic(用于数据验证)构建,可以提供自动请求验证、序列化和交互式文档,并且全程只需极少的样板代码。

立即学习“Python免费学习笔记(深入)”;

FastAPI 非常适合那些优先考虑速度、简洁性和标准的团队。 无论是 Web 开发者还是数据科学家,都对它青睐有加。

FastAPI 的优点

非常适合 AI/ML:FastAPI 广泛用于在生产环境中部署机器学习模型。 它能与TensorFlow、PyTorch、Hugging Face等库良好集成,并且支持异步模型推理管道,可以实现最大吞吐量。 默认支持异步:FastAPI 基于ASGI构建,支持原生的 async/await,非常适合实时应用、流式端点和低延迟机器学习服务。 类型安全且现代化:FastAPI 借助 Python 的类型提示自动验证请求,并生成简洁、适配编辑器的代码,既能减少运行时错误,又能提升团队效率。 自动生成的文档:FastAPI 通过Swagger UI和ReDoc创建交互式文档,团队无需额外编写文档,即可轻松探索和测试端点。 社区发展势头强劲:尽管 FastAPI 相对较新,但已形成庞大且活跃的社区,扩展程序、教程和集成生态系统也在持续完善。

FastAPI 的缺点

异步开发学习曲线陡峭:async/await 虽能提升性能,但对于新接触异步编程的开发者来说,调试、测试和并发管理都会是不小的挑战。 无内置核心工具:FastAPI 未自带身份验证、管理面板和数据库管理相关工具。 这些功能都需要开发者自行选择并手动集成。 生态系统规模较小:尽管 FastAPI 的插件生态正在发展,但仍落后于 Django。对于 CMS 集成或基于角色的访问控制等任务,现成可用的工具数量相对较少。

Django

2024 年使用率:35%(较 2023 年增长 2%)

Django再次跻身于最受开发者欢迎的 Python 框架之列。

Django 最初是为快速开发而构建的,具有内置的安全性和结构,此后它已发展成为一个全栈工具包。 从内容丰富的网站到数据科学仪表板以及由机器学习赋能的服务,它在各个领域都备受信赖。

它遵循模型-模板-视图 (MTV)模式,并配备了用于路由、数据访问和用户管理的内置工具。 这使得团队能够以最少的设置从构思推进到部署。

Django 的优点

内部功能齐全:Django 拥有一套全面的内置工具,包括 ORM、用户身份验证工具、管理面板和模板引擎。 这使其成为希望快速推进项目而无需自行搭建技术栈的团队的理想选择。 默认具备安全性:内置防护机制,可以抵御 CSRF、SQL 注入、XSS 等其他常见安全漏洞。 正是凭借安全优先的设计理念,Django 备受银行、政府机构和大型企业的信赖。 可扩缩且适用于生产环境:Django 支持水平扩缩、缓存和异步视图。 Instagram、Pinterest、Disqus 等高流量平台均采用它来提供技术支持。 出色的文档:Django 官方文档以清晰详尽著称,无论是新手开发者还是资深工程师,都能轻松理解和使用。 成熟的生态系统:目前已有数千个第三方软件包可供使用,覆盖 CMS 平台、REST API、支付、搜索等各类场景。 长期支持:在Django Software Foundation的支持下,Django 会定期推出更新、安全补丁和 LTS 版本,是长期项目的可靠选择。

Django 的缺点

对小型应用而言过于重量级:对于简单 API 或微服务,Django 的全栈设计可能显得冗余,并且配置过程耗时。 组件耦合度高:替换技术栈中的部分组件(如 ORM 或模板引擎)往往需要额外的变通方案或深度自定义。 学习曲线陡峭:对于新手开发者,或习惯了轻量级框架的团队来说,Django 的各类约定及复杂特性可能会让人望而却步。

Flask

2024 年使用率:34%(较 2023 年增长 1%)

Flask是适用于小型应用、API 和数据科学仪表板的最受欢迎的 Python 框架之一。

它是一款轻量级、无固定约束的 Web 框架,能让您完全掌控应用程序架构。 Flask 被归为“微框架”,原因在于它不强制要求特定的项目结构,也不包含 ORM 或表单验证等内置工具。

相反,它仅提供简洁的核心,允许您按需添加组件。 Flask 基于Werkzeug(一款 WSGI 实用程序库)和Jinja2(一款模板引擎)构建。 它以简洁的语法、直观的路由机制和灵活性而著称。

搭配SQLAlchemy、Flask-Login或 Flask-RESTful 等扩展使用时,Flask 的可扩缩性十分出色。

Flask 的优点

轻量且灵活:Flask 不强制结构或依赖项,非常适合微服务、API 以及希望从零开始搭建技术栈的团队。 在数据科学和机器学习工作流中很受欢迎:Flask 常被用于实验,例如构建仪表板、提供模型,或将 Notebook 转化为轻量级 Web 应用。 对新手友好:Flask 配置极简,学习曲线平缓,常被推荐为 Python 开发者入门的第一款 Web 框架。 可扩展:丰富的扩展程序生态系统能让您在需要时按需添加数据库集成、表单验证、身份验证等功能。 模块化架构:Flask 的设计便于将应用拆分为蓝图,或与其他服务集成,非常适合开发分布式系统的团队。 代码库易读:Flask 的源代码简洁易懂,无论是调试、自定义,还是复刻内部工具,都更为轻松。

Flask 的缺点

需自行整合各类组件:与 Django 不同,Flask 不包含 ORM、管理面板和用户管理功能。 这些都需要您自行选择并集成。 需手动搭建安全性:Flask 仅提供最基础的内置防护,CSRF 防护、输入验证和其他最佳做法需要您手动实现。 容易失控:由于没有统一的约定和结构,如果不自行规范架构与模式,大型 Flask 应用的维护工作颇有难度。

Requests

2024 年使用率:33%(较 2023 年增长 3%)

Requests并非 Web 框架,而是一款用于发起 HTTP 请求的 Python 库,但它对 Python 生态系统的影响力不容小觑。 它是 PyPI 上下载量最高的软件包之一,无论是网页爬虫脚本,还是生产级微服务,都会用到它。

Requests 常与 Flask 或 FastAPI 等框架搭配使用,以处理外部 HTTP 调用。 它屏蔽了原始套接字 和 urllib 的复杂逻辑,为网络数据的发送与接收提供了简洁、符合 Python 风格的接口。

Requests 的优点

简洁直观:Requests 让 HTTP 如同 Python 的原生功能一般自然。 它的语法简洁易读,只需使用 requests.get(url) 即可获取资源。 成熟稳定:历经十余年开发,Requests 已通过实战验证,广受信赖。 它被数百万开发者使用,并且是许多 Python 项目中的默认依赖项。 非常适合 REST 客户端:无论是使用 API、与 SaaS 平台集成,还是构建依赖外部数据源的内部工具,Requests 都是理想之选。 出色的文档与社区:官方文档清晰简洁,同时有教程、Stack Overflow 解答和 GitHub 问题为该库提供有力支持。 广泛的兼容性:Requests 在各 Python 版本和平台上都能无缝运行,提供了对会话、Cookie、标头和超时设置的内置支持。

Requests 的缺点

非异步:Requests 本质是同步阻塞式设计。 对于高并发工作负载或异步原生框架,HTTPX 或 AIOHTTP 等替代选择更为适合。 无内置重试逻辑:尽管支持连接池和超时,但重试行为必须手动或借助 urllib3 等第三方包装器实现。 底层控制有限:Requests 简化了 HTTP 调用,但也隐藏了网络细节,使得高级调优(如套接字、DNS、连接复用等)变得困难。

Asyncio

2024 年使用率:23%(较 2023 年增长 3%)

Asyncio是 Python 用于异步编程的原生库。 它是众多现代异步框架的底层基础,能让开发者借助协程、事件循环和 async/await 语法编写非阻塞代码。

AI智研社 AI智研社

AI智研社是一个专注于人工智能领域的综合性平台

AI智研社 15 查看详情 AI智研社

尽管 Asyncio 本身并非 Web 框架,但其在处理网络请求和子进程等 I/O 密集型任务时表现出色。 它虽常以幕后角色发挥作用,却是构建自定义异步工作流或与底层协议集成的强大工具。

Asyncio 的优点

原生异步支持:Asyncio 是 Python 标准库的一部分,通过 async/await 语法为异步 I/O 提供了一流支持。 现代框架的基础:它为如今众多热门异步 Web 框架(包括 FastAPI、Starlette 和 AIOHTTP)提供支持。 精细控制:开发者可以精准管理事件循环、调度协程,以及协调并发任务,非常适合构建自定义异步系统。 高效处理 I/O 密集型负载:在应对大量并发 I/O 操作(如 API 调用、套接字连接或文件读取)方面,Asyncio 表现出色。

Asyncio的缺点

学习曲- 线陡峭:对于新接触异步编程的开发者而言,协程、事件循环和任务调度等概念理解难度较大。

非完整框架:Asyncio 不提供路由、模板或请求处理功能。 它是一款底层工具,用于 Web 开发时需配合使用其他库。 调试复杂:异步代码的跟踪与调试难度更高,尤其在处理竞争条件或嵌套协程时。

Django REST Framework

2024 年使用率:20%(较 2023 年增长 2%)

Django REST Framework(DRF) 是在 Django 基础上构建 API 的最常用扩展。 它提供了一个强大且灵活的工具包,可用于数据序列化、权限管理和 RESTful 端点公开,且所有功能均与 Django 核心组件紧密集成。

DRF 在企业级应用和后端密集型应用程序中尤为流行,这类场景下的团队通常已在使用 Django,并且希望无需切换技术栈,就能借助 DRF 公开简洁、可扩缩的 API。 此外,可浏览 API 界面也是其一大特色,能让开发过程中的端点测试与调试变得更轻松。

Django REST Framework 的优点

深度 Django 集成:DRF 直接基于 Django 的模型、视图和身份验证系统构建,这使其成为已在使用 Django 的团队的自然选择。 可浏览 API 界面:DRF 的核心功能之一是基于 Web 的交互式 API 查看器,开发者与测试人员无需借助外部工具即可直接检查端点。 灵活的序列化:DRF 的序列化器功能全面,既能处理简单字段,也能支持深度嵌套关系,并且同时支持 ORM 和非 ORM 数据源。 完善的权限系统:DRF 包含对基于角色的访问控制、对象级权限和自定义授权逻辑的内置支持。 丰富的文档:DRF 文档详尽,且广泛教授。社区规模庞大,拥有大量教程、示例和第三方软件包。

Django REST Framework 的缺点

依赖 D- jango 且设置较繁琐:DRF 与 Django 绑定紧密,相比 FastAPI 等轻量级框架,需要更多配置,尤其是在自定义行为时。

序列化灵活性不足:DRF 的序列化器在常见用例下表现良好,但面对复杂或非标准数据时,自定义序列化逻辑往往需要编写大量冗余的重写代码。

其他优质框架:第 7–10 名

框架 概览 优点 缺点 httpx

2024年使用率:15%(较 2023 年增长 3%)

适用于同步与异步工作流的现代 HTTP 客户端

异步支持、HTTP/2、重试和类型提示

非 Web 框架,不具备路由和服务器端功能

aiohttp

2024年使用率:13%(较 2023 年增长 1%)

适用于 HTTP 服务器与客户端的异步工具包

支持 ASGI、原生 WebSocket 处理和灵活的中间件

相比 FastAPI 更偏底层,对于大型应用而言结构性较弱。

Streamlit

2024年使用率:12%(较 2023 年增长 4%)

适用于数据工作流的仪表板与数据应用构建器

支持快速 UI 原型开发,无需任何前端知识

对布局的控制能力有限,不太适合构建复杂 UI。

Starlette

2024年使用率:8%(较 2023 年增长 2%)

FastAPI 使用的轻量级 ASGI 框架

具备卓越性能、可组合式设计和精细路由能力

需手动集成,内置便捷功能较少

源码地址:点击下载

以上就是JetBrains 调研:2025 年最受欢迎的 Python 框架和库的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/317628.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月5日 08:32:09
下一篇 2025年11月5日 08:33:52

相关推荐

  • 如何解决本地图片在使用 mask JS 库时出现的跨域错误?

    如何跨越localhost使用本地图片? 问题: 在本地使用mask js库时,引入本地图片会报跨域错误。 解决方案: 要解决此问题,需要使用本地服务器启动文件,以http或https协议访问图片,而不是使用file://协议。例如: python -m http.server 8000 然后,可以…

    2025年12月24日
    200
  • 使用 Mask 导入本地图片时,如何解决跨域问题?

    跨域疑难:如何解决 mask 引入本地图片产生的跨域问题? 在使用 mask 导入本地图片时,你可能会遇到令人沮丧的跨域错误。为什么会出现跨域问题呢?让我们深入了解一下: mask 框架假设你以 http(s) 协议加载你的 html 文件,而当使用 file:// 协议打开本地文件时,就会产生跨域…

    2025年12月24日
    200
  • HTML、CSS 和 JavaScript 中的简单侧边栏菜单

    构建一个简单的侧边栏菜单是一个很好的主意,它可以为您的网站添加有价值的功能和令人惊叹的外观。 侧边栏菜单对于客户找到不同项目的方式很有用,而不会让他们觉得自己有太多选择,从而创造了简单性和秩序。 今天,我将分享一个简单的 HTML、CSS 和 JavaScript 源代码来创建一个简单的侧边栏菜单。…

    2025年12月24日
    200
  • 前端代码辅助工具:如何选择最可靠的AI工具?

    前端代码辅助工具:可靠性探讨 对于前端工程师来说,在HTML、CSS和JavaScript开发中借助AI工具是司空见惯的事情。然而,并非所有工具都能提供同等的可靠性。 个性化需求 关于哪个AI工具最可靠,这个问题没有一刀切的答案。每个人的使用习惯和项目需求各不相同。以下是一些影响选择的重要因素: 立…

    2025年12月24日
    000
  • 带有 HTML、CSS 和 JavaScript 工具提示的响应式侧边导航栏

    响应式侧边导航栏不仅有助于改善网站的导航,还可以解决整齐放置链接的问题,从而增强用户体验。通过使用工具提示,可以让用户了解每个链接的功能,包括设计紧凑的情况。 在本教程中,我将解释使用 html、css、javascript 创建带有工具提示的响应式侧栏导航的完整代码。 对于那些一直想要一个干净、简…

    2025年12月24日
    000
  • 布局 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在这里查看视觉效果: 固定导航 – 布局 – codesandbox两列 – 布局 – codesandbox三列 – 布局 – codesandbox圣杯 &#8…

    2025年12月24日
    000
  • 隐藏元素 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看隐藏元素的视觉效果 – codesandbox 隐藏元素 hiding elements hiding elements hiding elements hiding elements hiding element…

    2025年12月24日
    400
  • 居中 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看垂直中心 – codesandbox 和水平中心的视觉效果。 通过 css 居中 垂直居中 centering centering centering centering centering centering立即…

    2025年12月24日 好文分享
    300
  • 如何在 Laravel 框架中轻松集成微信支付和支付宝支付?

    如何用 laravel 框架集成微信支付和支付宝支付 问题:如何在 laravel 框架中集成微信支付和支付宝支付? 回答: 建议使用 easywechat 的 laravel 版,easywechat 是一个由腾讯工程师开发的高质量微信开放平台 sdk,已被广泛地应用于许多 laravel 项目中…

    2025年12月24日
    000
  • 如何在移动端实现子 div 在父 div 内任意滑动查看?

    如何在移动端中实现让子 div 在父 div 内任意滑动查看 在移动端开发中,有时我们需要让子 div 在父 div 内任意滑动查看。然而,使用滚动条无法实现负值移动,因此需要采用其他方法。 解决方案: 使用绝对布局(absolute)或相对布局(relative):将子 div 设置为绝对或相对定…

    2025年12月24日
    000
  • 移动端嵌套 DIV 中子 DIV 如何水平滑动?

    移动端嵌套 DIV 中子 DIV 滑动 在移动端开发中,遇到这样的问题:当子 DIV 的高度小于父 DIV 时,无法在父 DIV 中水平滚动子 DIV。 无限画布 要实现子 DIV 在父 DIV 中任意滑动,需要创建一个无限画布。使用滚动无法达到负值,因此需要使用其他方法。 相对定位 一种方法是将子…

    2025年12月24日
    000
  • 移动端项目中,如何消除rem字体大小计算带来的CSS扭曲?

    移动端项目中消除rem字体大小计算带来的css扭曲 在移动端项目中,使用rem计算根节点字体大小可以实现自适应布局。但是,此方法可能会导致页面打开时出现css扭曲,这是因为页面内容在根节点字体大小赋值后重新渲染造成的。 解决方案: 要避免这种情况,将计算根节点字体大小的js脚本移动到页面的最前面,即…

    2025年12月24日
    000
  • Nuxt 移动端项目中 rem 计算导致 CSS 变形,如何解决?

    Nuxt 移动端项目中解决 rem 计算导致 CSS 变形 在 Nuxt 移动端项目中使用 rem 计算根节点字体大小时,可能会遇到一个问题:页面内容在字体大小发生变化时会重绘,导致 CSS 变形。 解决方案: 可将计算根节点字体大小的 JS 代码块置于页面最前端的 标签内,确保在其他资源加载之前执…

    2025年12月24日
    200
  • Nuxt 移动端项目使用 rem 计算字体大小导致页面变形,如何解决?

    rem 计算导致移动端页面变形的解决方法 在 nuxt 移动端项目中使用 rem 计算根节点字体大小时,页面会发生内容重绘,导致页面打开时出现样式变形。如何避免这种现象? 解决方案: 移动根节点字体大小计算代码到页面顶部,即 head 中。 原理: flexível.js 也遇到了类似问题,它的解决…

    2025年12月24日
    000
  • 形状 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看 codesandbox 的视觉效果。 通过css绘制各种形状 如何在 css 中绘制正方形、梯形、三角形、异形三角形、扇形、圆形、半圆、固定宽高比、0.5px 线? shapes 0.5px line .square { w…

    2025年12月24日
    000
  • 有哪些美观的开源数字大屏驾驶舱框架?

    开源数字大屏驾驶舱框架推荐 问题:有哪些美观的开源数字大屏驾驶舱框架? 答案: 资源包 [弗若恩智能大屏驾驶舱开发资源包](https://www.fanruan.com/resource/152) 软件 [弗若恩报表 – 数字大屏可视化组件](https://www.fanruan.c…

    2025年12月24日
    000
  • 网站底部如何实现飘彩带效果?

    网站底部飘彩带效果的 js 库实现 许多网站都会在特殊节日或活动中添加一些趣味性的视觉效果,例如点击按钮后散发的五彩缤纷的彩带。对于一个特定的网站来说,其飘彩带效果的实现方式可能有以下几个方面: 以 https://dub.sh/ 网站为例,它底部按钮点击后的彩带效果是由 javascript 库实…

    2025年12月24日
    000
  • 网站彩带效果背后是哪个JS库?

    网站彩带效果背后是哪个js库? 当你访问某些网站时,点击按钮后,屏幕上会飘出五颜六色的彩带,营造出庆祝的氛围。这些效果是通过使用javascript库实现的。 问题: 哪个javascript库能够实现网站上点击按钮散发彩带的效果? 答案: 根据给定网站的源代码分析: 可以发现,该网站使用了以下js…

    好文分享 2025年12月24日
    100
  • 产品预览卡项目

    这个项目最初是来自 Frontend Mentor 的挑战,旨在使用 HTML 和 CSS 创建响应式产品预览卡。最初的任务是设计一张具有视觉吸引力和功能性的产品卡,能够无缝适应各种屏幕尺寸。这涉及使用 CSS 媒体查询来确保布局在不同设备上保持一致且用户友好。产品卡包含产品图像、标签、标题、描述和…

    2025年12月24日
    100
  • 如何利用 echarts-gl 绘制带发光的 3D 图表?

    如何绘制带发光的 3d 图表,类似于 echarts 中的示例? 为了实现类似的 3d 图表效果,需要引入 echarts-gl 库:https://github.com/ecomfe/echarts-gl。 echarts-gl 专用于在 webgl 环境中渲染 3d 图形。它提供了各种 3d 图…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信