Python实现Excel行列转换

这两天公司在进行人事系统切换,HR小同事焦头烂额的跑过来问我,有没有办法弄excel行列转换呀?我想了想:"用Excel的行列转换不就可以了吗?"啪啦啪啦的说了一堆,然后打开Excel给她演示。小同事不屑一顾:"这么简单还要问你呀!你看看我这个数据源,是所有员工的考勤数据,旧系统是行显示,新系统导入要按照列统计。要按照人员进行排列,还有缺勤的要留空...".一下子把我弄懵了,一下子还没想出简单快捷的办法。小同事又接着说,我现在手工一个个的弄,还不知道弄到什么时候呢。要不贴错了就苦逼了。看来,遇到棘手的还是想到了IT,我拍拍胸膛,这事包我身上。小同事一脸疑惑:"行吗"?"当然"。看来要再次搬出Python的看家伎俩了。没办法,谁让Python处理数据那是天生的?

原数据格式:

目标数据格式:

根据HR同事的要求,对需求进行了分析并归纳如下步骤:

  1. 读取数据源,将数据装入list中
  2. 从list中提取人员名单,去重
  3. 根据人员名单,筛选考勤记录,装入临时list中,进行日期处理,并返回到最终list, 删除临时表。
  4. 最终list写入原excel,完成。

参考代码如下:

from openpyxl import load_workbook

fname="source.xlsx"

def remove_duplicates(lst):#去重

return x for i, x in enumerate(lst) if i == lst.index(x)

def two_to_one(lst):

a=\[\]

for line in lst:

for perline in line:

a.append(perline)

return a

per_line=\[\]

total_line=\[\]

per_name_list=\[\]

name_list=\[\]

wb=load_workbook(fname,data_only=True) #读取数据源

ws=wb"Sheet4"

for row in ws.iter_rows():

i=0

for cell in row:

if i==1 or i==2 or i==3:

per_line.append(cell.value)

if i==1:

per_name_list.append(cell.value)

i+=1

total_line.append(per_line)

name_list.append(per_name_list)

per_line=\[\]

per_name_list=\[\]

name_list2=remove_duplicates(name_list1:)

print(name_list2) #打印去重后的名单

e_per_line=\[\]

e_line=\[\]

new_line=\[\]

new_line2=\[\]

all_list=\[\]

for line in name_list2:

#print(line)显示人名

for perline in total_line:

if line0==perline0:

e_per_line.append(perline1)

e_per_line.append(perline2)

if len(e_per_line)!=0:

e_line.append(e_per_line)

e_per_line=\[\]

#print(e_line)

new_line=two_to_one(e_line)

new_line2=line+new_line

#print(new_line2)

all_list.append(new_line2)

print("------------------")

e_line=\[\]

wb2=load_workbook('source.xlsx')#回写处理后的数据

ws2=wb2"Sheet31"

for line in all_list:

ws2.append(line)

wb2.save('source.xlsx')

相关推荐
AC赳赳老秦5 分钟前
用 OpenClaw 搭建服务器故障应急响应系统,自动处理 80% 常见运维故障
android·运维·服务器·python·rxjava·deepseek·openclaw
2601_9547064911 分钟前
云手机技术详解+Python实战调用|2026高稳云手机平台推荐
开发语言·python·智能手机
chushiyunen13 分钟前
java中的路径处理、左右斜杠
java·开发语言·python
jay神38 分钟前
基于 FastAPI + Vue 的宠物领养管理系统
前端·vue.js·python·毕业设计·fastapi·宠物
重生之后端学习43 分钟前
Java入门
java·开发语言·职场和发展
碧海蓝天20221 小时前
C++法则24:在标准 C++ 中,没有任何可移植的方式判断指针 T* pt 指向的内存位置是否已经 构造了对象,程序员必须手动跟踪哪些元素已构造。
java·开发语言·c++
代码不加糖1 小时前
Proxy能够监听到对象中的对象的引用吗?
开发语言·前端·javascript
charlie1145141911 小时前
现代C++指南:Lambda,让我们用另一种方式持有函数
开发语言·c++
程序员小远1 小时前
自动化测试基础知识总结
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
GEO优化小助手1 小时前
2026临沂GEO优化公司实测解析:3家本土机构适配性参考
大数据·人工智能·python