欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程语言 > python >内容正文

python

Python基础教程:一个单列split转换为多行的练习题

发布时间:2025/3/20 python 19 豆豆
生活随笔 收集整理的这篇文章主要介绍了 Python基础教程:一个单列split转换为多行的练习题 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

一、问题提出

实现如图所示的转换。

姓名年龄
A15
B、C16

用Python转换为:

姓名年龄
A15
B16
C16

二、解决问题

1.方法一:堆叠

''' 学习中遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025 寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书! ''' # 构建测试数据 import pandas as pd df = pd.DataFrame({'name':['a', 'b,c'],'age':[15, 16]}) print(df)df.set_index('age')['name'].str.split(',', expand=True).stack().reset_index(level=1, drop=True).reset_index(name='name') '''age name 0 15 a 1 16 b 2 16 c '''

2.方法二:循环

def shift(arr1, arr2):arr = []for k,v in dict(zip(arr1, arr2)).items():# print(k)# print(v)if isinstance(v, str):for s in v.split(','):arr.append({'name':k, 'age':s})return pd.DataFrame(arr)shift(df.age, df.name) '''age name 0 a 15 1 b 16 2 c 16 '''

总结

以上是生活随笔为你收集整理的Python基础教程:一个单列split转换为多行的练习题的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。