0

0

如何在 Polars 中将标量数值广播加到 List 列的每个元素上

聖光之護

聖光之護

发布时间:2026-01-14 11:22:24

|

172人浏览过

|

来源于php中文网

原创

如何在 Polars 中将标量数值广播加到 List 列的每个元素上

polars 1.10.0+ 支持 list 列与标量列的直接算术广播(如 `pl.col("lst") + pl.col("val")`) ,无需 `map_elements` 或嵌套 `list.eval`,简洁高效地实现逐元素加法。

在 Polars 中,对 List 列(如 pl.List 类型)执行“按行广播运算”——即把同一行中另一列的标量值加到该行 List 的每个元素上——曾长期受限于 list.eval 不支持跨列引用的限制。但自 Polars v1.10.0 起,这一场景已原生支持:List 列可直接与同长度的标量列进行算术运算,自动完成元素级广播

✅ 推荐方案(Polars ≥ 1.10.0):

import polars as pl

df = pl.DataFrame({
    'lst': [[0, 1], [9, 8]],
    'val': [3, 4]
})

result = df.with_columns(
    pl.col("lst") + pl.col("val")
)
print(result)

输出:

YouMind
YouMind

AI内容创作和信息整理平台

下载
shape: (2, 2)
┌───────────┬─────┐
│ lst       ┆ val │
│ ---       ┆ --- │
│ list[i64] ┆ i64 │
╞═══════════╪═════╡
│ [3, 4]    ┆ 3   │
│ [13, 12]  ┆ 4   │
└───────────┴─────┘

⚠️ 注意事项:

  • 此语法要求 Polars 版本 ≥ 1.10.0(请通过 pip install --upgrade polars 更新);
  • 运算自动按行对齐:第 i 行 lst 中的每个元素 + 第 i 行 val 的值;
  • 支持所有基础算术操作(+, -, *, /, //, %),语义与 NumPy/Pandas 广播一致;
  • 若 lst 中列表长度不一,仍能正确处理(无需预填充)。

? 替代方案(兼容旧版本或特殊需求):
若需兼容

# 适用于等长列表(默认 n_field_strategy="first")
df.with_columns(
    pl.col("lst").list.to_struct() + pl.struct("val")
)

# 若列表长度不一,推荐显式指定策略以避免截断
df.with_columns(
    (pl.col("lst").list.to_struct(n_field_strategy="max_width") 
     + pl.struct("val"))
)

⚠️ 注意:此方式返回 struct 类型而非 list,后续需用 .struct.unnest() 或字段索引访问,灵活性略低。

? 总结:
优先使用 pl.col("lst") + pl.col("val") —— 它是官方推荐、性能最优、语义最清晰的解决方案。避免过时的 list.eval(pl.element() + ...) 模式(会报错)或低效的 map_elements(丢失查询优化与类型推断)。升级 Polars 至最新稳定版,即可解锁这一关键生产力改进。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
Python 时间序列分析与预测
Python 时间序列分析与预测

本专题专注讲解 Python 在时间序列数据处理与预测建模中的实战技巧,涵盖时间索引处理、周期性与趋势分解、平稳性检测、ARIMA/SARIMA 模型构建、预测误差评估,以及基于实际业务场景的时间序列项目实操,帮助学习者掌握从数据预处理到模型预测的完整时序分析能力。

51

2025.12.04

pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

337

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

405

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

750

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

337

2025.07.23

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

12

2026.01.13

PHP 高性能
PHP 高性能

本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

22

2026.01.13

MySQL数据库报错常见问题及解决方法大全
MySQL数据库报错常见问题及解决方法大全

本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

18

2026.01.13

PHP 文件上传
PHP 文件上传

本专题整合了PHP实现文件上传相关教程,阅读专题下面的文章了解更多详细内容。

7

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号