python excel 自动化-python操作excel让工作自动化
某局某领导给了3只excel文件,一只里面有4个sheet需要处理,一个sheet有250+列,算下来总共有3000+列需要手动反复插入、删除列、拷贝、求和,所以给了4天的时间要完成。
我不愿意做大量简单而且又是重复性工作,看了看3只表格的格式基本一样,于是我用python写了30行代码完成了这个“艰巨”任务。
0x01
用python操作excel需要安装xlrd、xlwt(或者其他的模块也行)。
读取excel文件:workbook = xlrd.open_workbook('filename.xlsx')
获取所有表名:sheet_names = workbook.sheet_names()
通过索引顺序获取一个工作表:sheet0 = workbook.sheets()[0] || sheet1 = workbook.sheet_by_index(1)
通过名称获取一个工作表:sheet3= data.sheet_by_name(u'sheetname')
获取表的行、列大小:rows = sheet.nrows || cols = sheet.ncols
获取指定行、列的值:col0_value = sheet.col_valsue(0) || row0_value = sheet.row_values(0)
创建工作对象:wk = xlwt.Workbook(encoding='utf-8')
添加sheet对象:sheet0 = wk.add_sheet(sheetname,cell_overwrite=True)
将值写入单元格:sheet0.write(row,col,value)
保存文件:wk.save('filename.xls')
0x02
# coding=utf-8
import xlrd
import xlwt
workbook = xlrd.open_workbook('2014年排放量.xlsx')
sheet_names = workbook.sheet_names()
#通过索引顺序获取一个工作表
sheet0 = workbook.sheets()[0]
sheet1 = workbook.sheet_by_index(1)
sheet2 = workbook.sheet_by_index(2)
sheet3 = workbook.sheet_by_index(3)
sheet4 = workbook.sheet_by_index(4)
sheet5 = workbook.sheet_by_index(5)
sheet6 = workbook.sheet_by_index(6)
sheet7 = workbook.sheet_by_index(7)
sheet8 = workbook.sheet_by_index(8)
#通过名称获取一个工作表
#table = data.sheet_by_name(u'Sheet1')
#获取多少行、列
sht0_rows = sheet0.nrows
sht0_cols = sheet0.ncols
#获取指定单元格的值
temp = sheet0.cell(0,2)
#获取指定行、列的值
temp_col0 = sheet0.col_values(0)
temp_row0 = sheet0.row_values(0)
temp_col1 = sheet0.col_values(1)
temp_row1 = sheet0.row_values(1)
#需要204个单元格 一共tb0_rows个 减去前两个
'''
for i in range(204/6):#循环34次
for j in temp_row:
j[2:8]
'''
#print(tb0_rows,tb0_cols,temp,temp_row,temp_row[2:8],temp_col)
#取选定工作范围
#print(temp_row[2:206])
wk = xlwt.Workbook(encoding='utf-8')
wk_lst = []#创建sheet列表
for shtname in sheet_names:
#print(shtname)
wk_lst.append(wk.add_sheet(shtname,cell_overwrite_ok=True))
#print(len(wk_lst))
'''测试插入表格
for c in range(len(temp_col0)):
wk_lst[0].write(c,0,temp_col0[c])
#print(temp_col[c])
'''
#需要读的sheet列表
xlrd_sheet_list = [sheet0,sheet1,sheet2,sheet3]
for tm in range(len(wk_lst)):
if tm<4:
'''1. 创建样表'''
for x in range(2):
#print('----------x:',x)
temp_col = sheet0.col_values(x)
for c in range(len(temp_col)):
#print('--------c:',c)
#print(temp_col[c])
wk_lst[tm].write(c,x,temp_col[c])
temp_row = sheet0.row_values(0)
for r in range(len(temp_row)-2):
#print(tm,len(temp_row))
wk_lst[tm].write(0,r+2,temp_row[r+2])
'''2. 写入工作区域'''
for r in range(2,13):#创建工作行
tmp_row = xlrd_sheet_list[tm].row_values(r)
w = tmp_row[2:206] # 切片获取该行工作列
#print(len(w) / 6)
x = 0
for i in range(int(len(w) / 6)):
sum_pf = round(w[0 + x] + w[1 + x] + w[2 + x] + w[3 + x] + w[4 + x] + w[5 + x], 2)
wk_lst[tm].write(r,2+x,sum_pf)
print(sum_pf)
x += 6
print("----------------------------------------r:",r,2+x,sum_pf)
#for i in range(2,13):
# print(i)
wk.save('nb.xls')
'''#测试创建excel文件
wkt = xlwt.Workbook()
ws = wkt.add_sheet('CO')
ws.write(0,0,'1')
wkt.save('fuck.xls')
'''
'''
#临时注释 一会儿放开
for r in range(2,13):#创建工作行
tmp_row = sheet0.row_values(r)
w = tmp_row[2:206] # 切片获取该行工作列
#print(len(w) / 6)
x = 0
y = 0
for i in range(int(len(w) / 6)):
#wk_lst[0].write(2+)
print(round(w[0 + x] + w[1 + x] + w[2 + x] + w[3 + x] + w[4 + x] + w[5 + x], 2))
x += 6
print("----------------------------------------",r)
'''
'''#测试切片 相加
w = temp_row[2:206]#切片获取
print(len(w)/6)
x=0
for i in range(int(len(w)/6)):
print(round(w[0+x]+w[1+x]+w[2+x]+w[3+x]+w[4+x]+w[5+x],2))
x+=6
'''
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
python excel 自动化-python操作excel让工作自动化相关推荐
- 新技能 | 使用python代码来高效操作Excel表格 (文末赠书5本)
新技能 | 使用python代码来高效操作Excel表格 (文末赠书5本) 在日常学习和工作中,少不了要跟Excel表格打交道.而我们作为程序猿,深知代码编程给人带来的便捷性,那我们怎么样使用代码来操 ...
- python win32com + VBA宏 操作Excel,清除Excel中的公式
python win32com + VBA宏 操作Excel,清除Excel中的公式 最近有个需求是自动化清楚excel中的公式,尝试了使用openpyxl读取的时候不加载公式,但这样的结果是使用了公 ...
- 【Python数据分析】Python3操作Excel(二) 一些问题的解决与优化
[Python数据分析]Python3操作Excel(二) 一些问题的解决与优化 参考文章: (1)[Python数据分析]Python3操作Excel(二) 一些问题的解决与优化 (2)https: ...
- python 通过openpyxl来操作Excel文件(一 ):读取Excel文件
这篇文章讲python 通过openpyxl来读取Excel文件 不清楚怎么通过openpyxl来写入Excel文件的小伙伴可以看我另一篇文章 传送门python 通过openpyxl来操作Excel ...
- python 通过openpyxl来操作Excel文件(二 ):写入Excel文件
这篇文章讲python 通过openpyxl来写入Excel文件,不清楚python怎么读取Excel文件的小伙伴可以去看下我的另一篇文章 传送门https://blog.csdn.net/i_cof ...
- Python程序员的圣经——《Python编程快速上手:让繁琐工作自动化》尾末附下载地址
一.前言 如今,人们面临的大多数任务都可以通过编写计算机软件来完成.Python是一种解释型.面向对象.动态数据类型的高级程序设计语言.通过Python编程,我们能够解决现实生活中的很多任务. 今天给 ...
- Python编程快速上手,让繁琐工作自动化
大家好,我是辰哥(文末送书) 自学编程是不少人的选择,在著名的软件开发领域问答网站stackoverflow上,直接搜索learn programming可以得到47000多个回答,教我们如何学习某种 ...
- Python编程快速上手,让繁琐工作自动化(附下载)
今天给大家分享一份Python程序员的圣经--<Python编程快速上手:让繁琐工作自动化>.这是本面向实践的Python编程实用指南. 目录 第一章 Python基础 第二章 控制流 第 ...
- python让工作自动化_python操作excel让工作自动化
某局某领导给了3只excel文件,一只里面有4个sheet需要处理,一个sheet有250+列,算下来总共有3000+列需要手动反复插入.删除列.拷贝.求和,所以给了4天的时间要完成. 我不愿意做大量 ...
- Python批量下载电子邮件附件并汇总合并Excel文件_如何让繁琐工作自动化:聊聊Python与RPA...
RPA,是Robotic Process Automation的英文缩写,中文是机器人流程自动化,利用软件将重复性的工作自动化.基本目标是让人从重复性强的繁琐工作中解放出来去做更有意义更具创造性的工作 ...
最新文章
- ubuntu(16.04.01)学习-day1
- python程序设计报告-《Python程序设计》 实验报告.doc
- 从淘宝 UWP 的新功能 -- 比较页面来谈谈 UWP 的窗口多开功能
- html预览不出效果是怎么回事,为何HTML文件直接双击打不开 要用浏览器才能打开 之前双击还能打开显示效果的...
- python伪装浏览器什么意思_用python2和python3伪装浏览器爬取网页
- c++dll生成和调用
- c++ thread 内存泄漏_使用 ThreadLocal如何避免内存泄露?
- Tomcat输出catalina.out的大小控制
- React Native 加载多类型布局的实现——分类列表SectionList的封装
- mysql判断不等于空的脚本_Shell脚本中判断输入变量或者参数是否为空的方法
- numpy使用where函数定位满足条件的下标
- centos6.5 源码安装php7
- 长期大量收售通信 联通 移动 电信 工程各种型号光缆
- 命令行查看ubuntu版本号
- php中文手册 人间,写给成年人的人间参考手册 西瓜视频《2021,有一说一》今日上线...
- 中国数学界为之骄傲--庞加莱猜想的完美证明
- 东塔靶场之文件上传cms--pluck
- 科技企业家的自恋行为启示录
- 详解交换机的GVRP
- 阿里二面惨败,痛哭流涕狂刷 1000+ 面试题,成功面上五面上岸滴滴
热门文章
- Rsync数据同步服务
- webdriver --API--(java版) the second part
- C段渗透攻击必看的技术知识
- 2.Java异常学习
- DIRECTDRAW 1:创建一个简单的DIRECTDRAW程序
- python3.8.2安装教程-在服务器上安装python3.8.2环境的教程详解
- python代码编辑器排行榜-4款好用的Python编辑器,你用过几个?
- python开发系统-python3+django2开发一个简单的人员管理系统
- python实现文件下载-python实现文件上传下载
- python是什么怎么用-python函数是什么,怎么用?【python培训】