将字符串的前 3 个字符与特定列匹配

互联网 行业动态 更新时间:2024-06-13 00:21:05

Hen*_*ker 5

一种选择是Series.fillna+Series.str对前 3 个值进行切片:

df['id'] = df['id'].fillna(df['stat'].str[:3])
    id  value    stat
0  aaa   10.0  aaa123
1  aaa   20.0     NaN
2  aaa  500.0  aaa123
3  bbb   20.0     NaN
4  bbb   10.0  bbb123
5  aaa    5.0  aaa123
6  aaa    NaN  aaa123
7  c    NaN  c123

对于这种情况可能有点矫枉过正,但Series.str.extract也可以使用:

df['id'] = df['id'].fillna(df['stat'].str.extract(r'(^.{3})')[0])

mask如果这些是空字符串而不是NaN

df['id'] = df['id'].mask(df['id'].eq('')).fillna(df['stat'].str[:3])

更多推荐

字符串,字符

本文发布于:2023-04-23 10:35:36,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/hyzx/f0ee5654d4479d64de7bdeab92e18b86.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:字符串   字符

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!