python处理excel
在同一个sheet表中,将每个小表格删除最后两行合并,共用相同的抬头,合并后的表格序号要连续,最后导出到新的excel表中 什么意思,就是一个sheet里面不同位置没有重叠的俩表,删掉最后两行合并,然后导到新的excel里? 歌者文明清理员 发表于 2024-6-29 00:48什么意思,就是一个sheet里面不同位置没有重叠的俩表,删掉最后两行合并,然后导到新的excel里?
import pandas as pd
# 读取Excel文件
file_path = r'D:\try\merged_output_3.xlsx'
sheet_name = 'Sheet1'# 确保这是你要处理的那个Sheet表
df = pd.read_excel(file_path, sheet_name=sheet_name)
# 获取抬头
header = df.iloc
# 假设几个小表格之间有空行隔开
# 将合并后的数据放到一个列表中
merged_data = []
# 定义一个临时变量存储单个小表格
temp_table = []
# 遍历表格
for index, row in df.iterrows():
if row.isnull().all():
# 如果这一行全是空的,表示一个小表格结束
if temp_table:
temp_df = pd.DataFrame(temp_table)
merged_data.extend(temp_df.iloc[:-2].values.tolist())# 去掉最后两行
temp_table = []
else:
temp_table.append(row.values.tolist())
# 防止最后一个小表格漏掉
if temp_table:
temp_df = pd.DataFrame(temp_table)
merged_data.extend(temp_df.iloc[:-2].values.tolist())
# 创建合并后的DataFrame
merged_df = pd.DataFrame(merged_data, columns=header)
# 添加序号(如果没有的话)
if '序号' not in merged_df.columns:
merged_df.insert(0, '序号', range(1, len(merged_df) + 1))
else:
merged_df['序号'] = range(1, len(merged_df) + 1)
# 导出到新的Excel中
merged_df.to_excel(r"D:\ry\merged_output_2_next.xlsx" , index=False)
print("搞定!新的文件名叫做:合并后的表格.xlsx")
这是我现在的代码,运行完后无法共用同一个标题行,不知道咋改 pallas 发表于 2024-6-29 00:52
这是我现在的代码,运行完后无法共用同一个标题行,不知道咋改
header = df.iloc
改成
header = df.columns
我对 pandas 不是很熟,见谅 本帖最后由 pallas 于 2024-6-29 02:09 编辑
谢谢
页:
[1]