每天学点Polars:三、DataFrame的删除、合并、填充、爆炸!
liuian 2025-03-11 18:02 32 浏览
polars.DataFrame.drop_in_place
DataFrame.drop_in_place(name: str) → Series功能:删除指定列,并返回删除的列。
df = pl.DataFrame(
{
"foo": [1, 2, 3],
"bar": [6, 7, 8],
"ham": ["a", "b", "c"],
}
)
df.drop_in_place("ham")
# shape: (3,)
# Series: 'ham' [str]
# [
# "a"
# "b"
# "c"
# ]polars.DataFrame.drop_nulls
DataFrame.drop_nulls(
subset: ColumnNameOrSelector | Collection[ColumnNameOrSelector] | None = None,
) → DataFrame功能:删除所有包含null值的行,其余行按原始顺序保留。
参数:subset用于指定列名。默认为None,使用所有列。
df = pl.DataFrame(
{
"foo": [1, 2, 3],
"bar": [6, None, 8],
"ham": ["a", "b", None],
}
)
df.drop_nulls()
# shape: (1, 3)
# ┌─────┬─────┬─────┐
# │ foo ┆ bar ┆ ham │
# │ --- ┆ --- ┆ --- │
# │ i64 ┆ i64 ┆ str │
# ╞═════╪═════╪═════╡
# │ 1 ┆ 6 ┆ a │
# └─────┴─────┴─────┘import polars.selectors as cs
df.drop_nulls(subset=cs.integer())
# shape: (2, 3)
# ┌─────┬─────┬──────┐
# │ foo ┆ bar ┆ ham │
# │ --- ┆ --- ┆ --- │
# │ i64 ┆ i64 ┆ str │
# ╞═════╪═════╪══════╡
# │ 1 ┆ 6 ┆ a │
# │ 3 ┆ 8 ┆ null │
# └─────┴─────┴──────┘polars.DataFrame.explode
DataFrame.explode(
columns: str | Expr | Sequence[str | Expr],
*more_columns: str | Expr,
) → DataFrame功能:炸开指定的列。
参数:
- columns:列名。要炸开的列必须是List或Array类型。
- *more_columns:要分解的其他列名称。
df = pl.DataFrame(
{
"letters": ["a", "a", "b", "c"],
"numbers": [[1], [2, 3], [4, 5], [6, 7, 8]],
}
)
df
# shape: (4, 2)
# ┌─────────┬───────────┐
# │ letters ┆ numbers │
# │ --- ┆ --- │
# │ str ┆ list[i64] │
# ╞═════════╪═══════════╡
# │ a ┆ [1] │
# │ a ┆ [2, 3] │
# │ b ┆ [4, 5] │
# │ c ┆ [6, 7, 8] │
# └─────────┴───────────┘
df.explode("numbers")
# shape: (8, 2)
# ┌─────────┬─────────┐
# │ letters ┆ numbers │
# │ --- ┆ --- │
# │ str ┆ i64 │
# ╞═════════╪═════════╡
# │ a ┆ 1 │
# │ a ┆ 2 │
# │ a ┆ 3 │
# │ b ┆ 4 │
# │ b ┆ 5 │
# │ c ┆ 6 │
# │ c ┆ 7 │
# │ c ┆ 8 │
# └─────────┴─────────┘polars.DataFrame.extend
DataFrame.extend(
other: DataFrame,
) → DataFrame[source]功能:拓展DataFrame。
注意:此方法就地修改DataFrame,返回DataFrame只是为了方便。
df1 = pl.DataFrame({"foo": [1, 2, 3], "bar": [4, 5, 6]})
df2 = pl.DataFrame({"foo": [10, 20, 30], "bar": [40, 50, 60]})
df1.extend(df2)
# shape: (6, 2)
# ┌─────┬─────┐
# │ foo ┆ bar │
# │ --- ┆ --- │
# │ i64 ┆ i64 │
# ╞═════╪═════╡
# │ 1 ┆ 4 │
# │ 2 ┆ 5 │
# │ 3 ┆ 6 │
# │ 10 ┆ 40 │
# │ 20 ┆ 50 │
# │ 30 ┆ 60 │
# └─────┴─────┘polars.DataFrame.fill_nan
DataFrame.fill_nan(value: Expr | int | float | None) → DataFrame功能:使用指定的值替换浮点数NaN的值。
注意:和
polars.DataFrame.fill_null()区分。
df = pl.DataFrame(
{
"a": [1.5, 2, float("nan"), 4],
"b": [0.5, 4, float("nan"), 13],
}
)
df.fill_nan(99)
# shape: (4, 2)
# ┌──────┬──────┐
# │ a ┆ b │
# │ --- ┆ --- │
# │ f64 ┆ f64 │
# ╞══════╪══════╡
# │ 1.5 ┆ 0.5 │
# │ 2.0 ┆ 4.0 │
# │ 99.0 ┆ 99.0 │
# │ 4.0 ┆ 13.0 │
# └──────┴──────┘polars.DataFrame.fill_null
DataFrame.fill_null(
value: Any | Expr | None = None,
strategy: FillNullStrategy | None = None,
limit: int | None = None,
*,
matches_supertype: bool = True,
) → DataFrame功能:使用指定的值或策略填充null值。
value:
- value:指定值。
- strategy:策略,支持{None, ‘forward’, ‘backward’, ‘min’, ‘max’, ‘mean’, ‘zero’, ‘one’}。
- limit:使用“正向”或“反向”策略时要填充的连续 null 值的数量。
相关推荐
- 戴尔声卡驱动器官方下载(戴尔5502声卡驱动)
-
戴尔电脑声卡驱动是SoundCardDriver。声卡驱动就是指电脑多媒体声卡控制程序,英文名为"SoundCardDriver",是一种可以让电脑和声卡设备通信的特殊程序驱动...
- 电脑开不了机怎么做系统(电脑开不了机怎么样装系统)
-
1、在可用电脑上制作好U盘启动盘,将下载的电脑系统iso文件直接复制到U盘的GHO目录下;2、在开不了机的电脑上插入U盘,重启后不停按F12或F11或Esc等快捷键打开启动菜单,选择U盘选项回车,比如...
- u盘文件夹里面的文件不见了(u盘里的文件夹突然不见了怎么办)
-
可能出现以下几种情况:1.文件夹被隐藏了:在文件夹上右击->属性->勾选“隐藏”选项。2.文件被删除了:需要查看最近删除的文件。3.文件夹被移动了:通过搜索查找文件夹。4....
- 联想z6pro(联想官方售后服务中心官网)
-
联想Z6Pro5G版正面采用了时下流行的水滴屏设计,6.39英寸三星AMOLED材质,而对于担心频闪问题的消费者有一个好消息——联想Z6Pro5G版的屏幕全程采用了DC调光。笔者并未在设置...
-
- ie浏览器更新在哪里(ie浏览器在哪里更新版本)
-
1.打开桌面的IE浏览器2.点击菜单栏的的帮助3.打开关于InternetExplorer(A)4.自动安装新版本前面打勾即可。ie浏览器更新是很简单的,具体操作步骤如下:1、打开浏览器首先我们打开电脑桌面,然后在电脑上找到“浏览器”图标...
-
2025-12-15 05:05 liuian
- server2019开机黑屏只有cmd(server2019开机黑屏只有cmd怎么重装)
-
explorer是启动Windows窗口的执行文件,如果这个文件不执行,就不能打开Windows的窗口界面。可能是安装程序有问题,这个文件不存在。重新找一个安装文件,重新安装试一下。你先输入explo...
- 共享文件怎么弄(共享文件怎么弄出来)
-
为了安全地共享文件,具体的步骤如下:1)将文件复制到共享文件夹;2)设置文件权限,此处可以设置允许或拒绝他人读取、写入和修改文件;3)选择共享文件夹中的文件,用鼠标右键点击并选择“共享”;4)设置“共...
- 电脑摄像头怎么连接手机(电脑摄像头连接手机软件)
-
电脑手机方法/步骤1/4分步阅读首先打开电脑,然后将手机插入USB接口连接起来。在连接成功以后,在电脑上会自动进行驱动的安装。2/4之后手机上就会出现提示,我们在菜单中点击一下第二个“相机(PTP...
- 格式化命令和参数(格式化命令在哪个菜单中)
-
1,你用DM万用版或LFORMAT命令可实现硬盘的低格。2,用DOS的DEBUG命令也可实现低格操作如下:A:\>DEBUG-A100-,0703;交叉因子为3-,000...
- 电脑浏览器缓存怎么清理(电脑浏览器清理缓存怎么操作)
-
把浏览器直接删除。然后重新下载安装。一个浏览器在使用一段时间之后,往往会产生大量的缓存,严重影响电脑的运行,并且占有电脑大量的资源,那么很多清理缓存的方法它都是不彻底的,所以你不如直接把浏览器在电脑当...
- 笔记本电脑开机黑屏只显示鼠标
-
问题分析:电脑开机显示器不亮分两种情况:显示器未通电(电源指示灯不亮)或通电(电源指示灯亮)但无信号或屏幕显示“nosighal”,前者表示电路不通,或者是电源接口或电源线接触不良或损坏,后者一般是...
- 路由器详细设置教程(路由器设置方法及步骤)
-
步骤/方式一以TP-LINK无线路由器为例,将宽带网线接到路由器的LAN口。步骤/方式二用网线连接电脑和路由器。步骤/方式三打开浏览器,登录路由器管理界面。步骤/方式四点击设置向导。步骤/方式五选择让...
- linux系统下载到手机(linux安装到手机)
-
1、首先在手机设置中点击【安全】选项。2、然后在安全页面点击【支付保护】,关闭支付应用后面的开关即可。手机盾是以手机TEE(可信执行环境)和SE(安全元件)为载体实现的二代USBKEY,完全不依赖任何...
- tplink密码在哪看(如何查看tplink路由器密码)
-
输入192.168.1.1或者是192.168.0.1账号密码都是admin进去找到网络获取方式,拨号就可以看到账号了至于密码除非你那有选择显示密码,你才能看到,否则都是点点其实装网的时候...
- 一周热门
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
