Python解析Excel入库如何做到行的拆分

我们读取解析Excel入库经常会遇到这种场景,那就是行的拆分,如图:

比如我们入库,要以name为主键,可是表格name的值全是以逗号分割的多个,这怎么办呢?这就必须拆成多行了啊。

代码如下:

python 复制代码
from sqlalchemy import create_engine
import numpy as np
import pandas as pd
conn = create_engine("mysql+pymysql://user:pass@host:3306/db")
df = pd.read_excel("test.xlsx")
df.dropna(subset=["name"])    #删除空行
droplist=[]                 #记录带逗号的行号
for i in df.index:          #遍历每一行
  df_line = df.loc[[i]]        #本行
  names = df.loc[i,'name']
  name_list = names.split(',') 
  #逗号分割超过一条,拆成多行
  if(len(name_list)>1):
    droplist.append(i)     #删除原来的行
    for name in name_list:
      name = name.strip()
      df_line.loc[i,'name'] = name   #修改本行的字段值 也就形成了新行
      df = pd.concat([df,line],ignore_index=True)  #拆分的新行附加到最后面
      
df.drop(droplist,axis=0,inplace=True)   #删除原来有逗号的行

这样我们就得到了新的df,已经完成了重组,如图

相关推荐
Rabitebla8 小时前
vector 的骨架:三根指针、模板陷阱与迭代器失效的第一现场
开发语言·数据结构·c++·算法
时空系8 小时前
第7篇:功能——打造你的工具箱 Rust中文编程
开发语言·网络·rust
BU摆烂会噶8 小时前
【LangGraph】持久化实现的三大能力——人机交互
数据库·人工智能·python·langchain·人机交互
csbysj20208 小时前
CSS !important:深度解析与最佳实践
开发语言
初心未改HD8 小时前
Go语言测试与Benchmark:测试驱动开发的实践指南
开发语言·golang
chxii8 小时前
lua流程控制语句和table(表)数据结构
开发语言·junit·lua
.柒宇.8 小时前
AI掘金头条项目部署实践指南
linux·运维·python·fastapi
WL_Aurora8 小时前
Python 算法基础篇之树和二叉树
python·算法
逻辑驱动的ken8 小时前
Java高频面试考点场景题20
java·开发语言·深度学习·面试·职场和发展
W.A委员会8 小时前
多行溢出在末尾添加省略号
开发语言·javascript·css