Narwhals v1.24.1 发布:增强多后端兼容性与表达式处理能力
Narwhals 是一个专注于为不同数据处理后端提供统一接口的 Python 库,它允许开发者使用相同的 API 操作多种数据处理引擎,如 PySpark、DuckDB 等。最新发布的 v1.24.1 版本带来了一系列改进和新特性,进一步提升了库的兼容性和易用性。
核心功能增强
本次更新最值得关注的是对 SQLFrame 的初步支持。SQLFrame 是另一个 Python 数据操作库,Narwhals 开始为其提供兼容层,这意味着开发者未来可以在 SQLFrame 后端上使用 Narwhals 的统一 API。虽然当前支持还处于"静默"阶段,但这一变化为未来扩展多后端支持奠定了基础。
在表达式处理方面,v1.24.1 改进了 PySpark 的字面量处理机制,使其更加健壮。同时新增了 selectors.matches 方法,为数据选择操作提供了更灵活的匹配能力。对于 DuckDB 用户,新版本增强了对标量运算的支持,并优化了 IPython 环境下的显示宽度,提升了交互体验。
内部架构优化
开发团队对代码库进行了多项内部重构,降低了代码重复率。特别是重构了 name 命名空间的处理逻辑,使代码结构更加清晰。此外,移除了 DuckDBExpr 和 SparkLikeExpr 中未使用的 _depth 属性,简化了表达式类的实现。
类型系统也得到了加强,项目现在明确包含了 "typing :: typed" 分类器,表明其对类型提示的支持。函数参数处理也更加规范,在 evaluate_into_exprs 方法中使用了位置参数限定,提高了 API 的明确性。
开发者体验改进
对于使用 IPython 或 Jupyter Notebook 进行数据分析的用户,新版本增加了显示宽度,使得在交互式环境中查看数据更加方便。这些看似微小的改进实际上显著提升了日常开发体验。
总体而言,Narwhals v1.24.1 虽然是一个小版本更新,但在多后端支持、表达式处理和代码质量方面都做出了有价值的改进,为开发者提供了更稳定、更统一的数据操作体验。这些变化体现了项目团队对代码质量的持续关注和对多后端兼容性的长期投入。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0213
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0138
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
SwanLab⚡️SwanLab - an open-source, modern-design AI training tracking and visualization tool. Supports Cloud / Self-hosted use. Integrated with PyTorch / Transformers / LLaMA Factory / veRL/ Swift / Ultralytics / MMEngine / Keras etc.Python00
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook03