前言

某局某领导给了3只excel文件,一只里面有4个sheet需要处理,一个sheet有250+列,算下来总共有3000+列需要手动反复插入、删除列、拷贝、求和,所以给了4天的时间要完成。

我不愿意做大量简单而且又是重复性工作,看了看3只表格的格式基本一样,于是我用python写了30行代码完成了这个"艰巨”任务。

用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')

---------------------

# 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

'''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表格!使工作效率提升一倍不止!...相关推荐

  1. Excel教程:规范Excel表格设计,让工作效率提升百倍不止

    在工作中我们经常需要花费大量的时间来整理表格,而真正用在数据汇总的时间可能仅仅只有几分钟,这也就是所谓的,整理5小时汇总2分钟,所以说规范的设计表格以及录入数据会大大的提高我们的工作效率,让工作效率提 ...

  2. Excel教程:4个好用的Excel设置技巧,让工作效率提升十倍不止

    Hello,大家好,今天知识兔跟大家分享4个excel的设置技巧,在适合的场景使用这些设置能够在一定程度上提高我们的工作效率,设置也非常简单,下面就让我们来一起操作下 一.自动保存 相信大家在工作中都 ...

  3. python自动生成word报告_python自动化生成分析报告,让你的工作效率提升10倍+

    打开搜狗搜索APP,查看更多精彩资讯 如果你每天都需要输出分析报告,报告模式基本一致,只是更换里面的分析数据,每天重复着同样的工作,费时费力,工作能力没有丝毫的提升,但是如果你学过python,你就可 ...

  4. python对工作效率的提升_使用了这个几个Python内置小工具,可以让你的工作效率提升一倍...

    使用了这个几个Python内置小工具,可以让你的工作效率提升一倍 我们将会详情4个Python解释器自身提供的小工具. 这些小工具在笔者的日常工作中经常使用到, 减少了各种时间的白费, 然而,却很容易 ...

  5. 必须掌握的20个Excel技巧,让你的工作效率提升十倍

    知识的广度来自知识的深度,学习如果不成体系那是多可怕的一件事儿,希望我们在未来的学习道路上坚守初心,不要给自己留下遗憾,以自己喜欢的方式生活,做自己喜欢做的事,宠爱自己,做一个独一无二的自己! 对于文 ...

  6. 通Python实现操作 excel表格 工作效率提升百倍

    一.概述 操作 excel 是程序员经常要遇到的场景.因为产品.运营的数据都是以这种格式存储.所以,当程序员拿到这些数据肯定要解析,甚至需要把结果输出成 excel 文件. 下面就介绍如果用 Pyth ...

  7. python如何将多张excel表内数据求和_Excel批量操作,把你的工作效率提升10倍以上(1)...

    ​君子之交淡若水,小人之交甘若醴,君子淡以亲,小人甘以绝.--庄子 我们在日常工作中,遇到的最多的点,就是涉及到的内容很多,如果一个个的去查看,效率会非常慢,这时批量操作可以大大提升我们的工作效率,今 ...

  8. 6个 Python 办公黑科技,工作效率提升100倍!(附代码)

    下班晚,加班久感觉已经成为现代打工人的通病,每天将大部分时间浪费在一些机械,重复的工作上,如何提升你自己的工作效率才是关键. 今天给大家分享6个 Python 办公小技巧,让你的工作效率倍增,欢迎大家 ...

  9. python提高办公效率-用Python的这3个优点,让工作效率提升一倍

    如果你对数据分析有所了解,一定听说过一些亲民的工具如Excel.Tableau.PowerBI等,都能成为数据分析的得力助手.但它们的不足也是显而易见的:操作繁琐,复用性差,功能相对局限单一. 怎么解 ...

最新文章

  1. 深入理解MFC消息循环和消息泵的原理
  2. poj3713 Transferring Sylla 枚举+tarjan判割点
  3. Windows用户安全小技巧
  4. 太牛了,原来古人是这样铸造钱币的。。。
  5. MySQL 主从同步故障处理-小记
  6. 《掌门1对1微服务体系 Solar | 阿里巴巴 Sentinel 落地实践》
  7. python输入的数字为什么不能计算_计算器为什么只能进行个位数的计算,每次只能输入一个数字,求...
  8. 2018.11.08 NOIP模拟 景点(倍增+矩阵快速幂优化dp)
  9. WiredTiger存储引擎知多少?
  10. ansible基本模块-copy
  11. hdu 5461(2015沈阳网赛 简单暴力) Largest Point
  12. 【周末夜校】混音问题——字符串函数
  13. linux安装pyodbc模块,Linux下安装pyodbc报错 error: command 'gcc' failed with exit status 1
  14. EXCEL冻结窗口只想冻结前两行
  15. go module使用教程:使用go mod的方法.报错go: cannot determine module path for source directory E:\tttttt (outside
  16. 【深度学习】YOLOv7目标检测模型使用记录 yolov7-tiny
  17. 小型元器件介绍:排阻
  18. 微星MSI新笔记本外接耳机没有声音?完美解决
  19. matlab去除红眼代码及详细介绍
  20. 怎么用计算机解锁,一加6T解锁BL教程,利用电脑进行一键解锁Bootloader操作

热门文章

  1. 修改云服务器上文件夹只读属性,求助:为什么我电脑里的文件夹会自动变为只读属性?...
  2. 括号表示法字符串构造二叉树_一篇文章学会二叉树和二叉查找树
  3. matlab知识集锦
  4. OCR:深度学习-目标检测-超详细图解Faster R-CNN
  5. 如何排查mysql数据乱码_如何解决MYSQL数据库中文乱码问题?
  6. 查看mysql所有命令
  7. CCF认证201712-2游戏
  8. 国家哲学社会科学文献中心
  9. [LeetCode] 81. Search in Rotated Sorted Array II
  10. jquery 获取子元素的限制jquery