python操作excel让工作自动化


Posted in Python onAugust 09, 2019

某局某领导给了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 相关文章推荐
跟老齐学Python之编写类之一创建实例
Oct 11 Python
python自动裁剪图像代码分享
Nov 25 Python
python中正则表达式 re.findall 用法
Oct 23 Python
python3爬虫学习之数据存储txt的案例详解
Apr 24 Python
详解Selenium+PhantomJS+python简单实现爬虫的功能
Jul 14 Python
python使用原始套接字发送二层包(链路层帧)的方法
Jul 22 Python
Django model 中设置联合约束和联合索引的方法
Aug 06 Python
Flask框架路由和视图用法实例分析
Nov 07 Python
pytorch dataloader 取batch_size时候出现bug的解决方式
Feb 20 Python
python TCP包注入方式
May 05 Python
keras slice layer 层实现方式
Jun 11 Python
Python包argparse模块常用方法
Jun 04 Python
python笔记_将循环内容在一行输出的方法
Aug 08 #Python
python中的列表与元组的使用
Aug 08 #Python
详解python中的数据类型和控制流
Aug 08 #Python
python爬虫selenium和phantomJs使用方法解析
Aug 08 #Python
Python2和3字符编码的区别知识点整理
Aug 08 #Python
Python编程中类与类的关系详解
Aug 08 #Python
python os.fork() 循环输出方法
Aug 08 #Python
You might like
PHP5 面向对象程序设计
2008/02/13 PHP
php除数取整示例
2014/04/24 PHP
php中socket通信机制实例详解
2015/01/03 PHP
高质量PHP代码的50个实用技巧必备(下)
2016/01/22 PHP
boxy基于jquery的弹出层对话框插件扩展应用 弹出层选择器
2010/11/21 Javascript
JQuery1.6 使用方法三
2011/11/23 Javascript
js模拟点击事件实现代码
2012/11/06 Javascript
js如何判断用户是在PC端和还是移动端访问
2014/04/24 Javascript
node.js中的fs.truncate方法使用说明
2014/12/15 Javascript
谈一谈js中的执行环境及作用域
2016/03/30 Javascript
jQuery遍历json的方法分析
2016/04/16 Javascript
第一章之初识Bootstrap
2016/04/25 Javascript
详解Angular.js的$q.defer()服务异步处理
2016/11/06 Javascript
AngularJS中的Promise详细介绍及实例代码
2016/12/13 Javascript
vue2.0 自定义组件的方法(vue组件的封装)
2018/06/05 Javascript
vue实现带复选框的树形菜单
2019/05/27 Javascript
JS数组扁平化、去重、排序操作实例详解
2020/02/24 Javascript
JS实现百度搜索框
2021/02/25 Javascript
[01:06:26]全国守擂赛第二周 Team Coach vs DeMonsTer
2020/04/28 DOTA
利用Python中的mock库对Python代码进行模拟测试
2015/04/16 Python
浅谈python多线程和队列管理shell程序
2015/08/04 Python
python如何实现异步调用函数执行
2019/07/08 Python
python利用itertools生成密码字典并多线程撞库破解rar密码
2019/08/12 Python
pycharm中导入模块错误时提示Try to run this command from the system terminal
2020/03/26 Python
使用Python Tkinter实现剪刀石头布小游戏功能
2020/10/23 Python
来自世界上最好大学的在线课程:edX
2018/10/16 全球购物
劳资专员岗位职责
2013/12/27 职场文书
茶叶店创业计划书范文
2014/01/19 职场文书
安全生产检讨书
2014/01/21 职场文书
劳动之星获奖感言
2014/02/01 职场文书
应届生求职信
2014/05/31 职场文书
生活小常识广播稿
2015/08/19 职场文书
教师远程研修感悟
2015/11/18 职场文书
导游词之南京栖霞山
2019/10/18 职场文书
CSS中em的正确打开方式详解
2021/04/08 HTML / CSS
详解JS WebSocket断开原因和心跳机制
2021/05/07 Javascript