Python办公自动化学习笔记--Excel

1.对单元格的读写操作

*写操作

import xlwt     #先下载:win+R打开命令框输入pip install xlwt

new_writebook=xlwt.Workbook()

worksheet=new_writebook.add_sheet('new_test')

worksheet.write(0,0,"test")

new_writebook.save('d:/test.xls')

解释:xlwt.workbook新建一个test.xls表格,

add_sheet表示整个Excel文件的第一页,叫做new_test

write在0行0列(也就是左上角第一个单元格)写入test

save方法后上面的操作才生效

*读操作

import   xlrd    #先下载:win+R打开命令框输入pip install xlrdxlsx=xlrd.open_workbook('d:/test.xls')

table=xlsx.sheet_by_index(0)

#table=xlsx.sheet_by_name('new_test')

print(table.cell_value(0,0))

#print(table.cell(0,0).value)

#print(table.row(0)[0].value)

解释:选择xlsx文件中的某一个表格:byname或者byindex

打印的三种方式!

2.写入带样式的数据

from xlutils.copy import copy

import xlrd

import xlwt

new_tem=xlrd.open_workbook('d:/python_test/test.xls',formatting_info=True)

#一定要带formatting_info=True,不然原有的数据格式无法复制到新的文件中

new_excel=copy(new_tem)#新的xlsx文件

new_sheet=new_excel.get_sheet(0)#新文件的第一页是所copy文件的第一页

style1=xlwt.XFStyle()#新建一个样式,写入数据时使用

#设置字体

font1=xlwt.Font()

font1.name='微软雅黑'

font1.bold=True

font1.height=320#在Excel中所设置的字体大小*20

style1.font=font1#加入到style1样式中

#单元格边框样式

borders=xlwt.Borders()

borders.top=xlwt.Borders.THIN#细线

borders.bottom=xlwt.Borders.THIN

borders.left=xlwt.Borders.THIN

borders.right=xlwt.Borders.THIN

style1.borders=borders#加入到style1样式中

#位置:居中或其他方式

alignment1=xlwt.Alignment()

alignment1.horz=xlwt.Alignment.HORZ_CENTER#水平居中

alignment1.vert=xlwt.Alignment.VERT_CENTER#垂直居中

style1.alignment=alignment1#加入到style1样式中

#写数据

new_sheet.write(1,1,62,style1)#一定要带样式才能写入带样式的数据

new_sheet.write(2,1,63,style1)#单元格左上角的格子坐标为(0,0)

new_sheet.write(3,1,64,style1)

new_excel.save('d:/python_test/test2.xls')#保存这个新文件

注意一点:打开的时候要写上formatting_info=True

3.习题:生成一个统计数表

#生成数据统计表格带样式:也就是第一列可能在表格中重复出现,他右边的单元格是他的数值

#                      将他们的数值加在一起进行统计,只保留第一列的一个数据

import xlrd

import xlwt

from xlutils.copy import copy

xlsx=xlrd.open_workbook('d:/python_test/test2.xls')#test2是原始要进行统计的xls文件

table=xlsx.sheet_by_index(0)#打开所要读取数据的表格:test的第一页

all_data=[]#存储所有读到的数据

forninrange(1,table.nrows):#第一行到最后一行

date=table.cell(n,0).value#第n行第0列的单元格

points=table.cell(n,1).value#第n行第一列的单元格

data={'date':date,'points':points}#每一行的数据封装,'date'和'points'相当于变量

all_data.append(data)#[]里面是{}的集合

#我的test2中只有三个年份的数据,所以定义三个

apoints=0

bpoints=0

cpoints=0

for i in all_data:

ifi['date']==2000:

apoints=apoints+i['points']#重复数据相加

ifi['date']==2001:

bpoints=bpoints+i['points']

ifi['date']==2002:

cpoints=cpoints+i['points']


#定义样式:这里我使用的是test表格中的样式,也就是说,样式表和原始表格可以不是同一个

new_tem=xlrd.open_workbook('d:/python_test/test.xls',formatting_info=True)

#一定要带formatting_info=True,不然原有的数据格式无法复制到新的文件中

new_excel=copy(new_tem)#新的xlsx文件

new_sheet=new_excel.get_sheet(0)#新文件的第一页是所copy文件的第一页

style1=xlwt.XFStyle()#新建一个样式,写入数据时使用

#设置字体

font1=xlwt.Font()

font1.name='微软雅黑'

font1.bold=True

font1.height=320#在Excel中所设置的字体大小*20

style1.font=font1#加入到style1样式中

#单元格边框样式

borders=xlwt.Borders()

borders.top=xlwt.Borders.THIN#细线

borders.bottom=xlwt.Borders.THIN

borders.left=xlwt.Borders.THIN

borders.right=xlwt.Borders.THIN

style1.borders=borders#加入到style1样式中

#位置:居中或其他方式

alignment1=xlwt.Alignment()

alignment1.horz=xlwt.Alignment.HORZ_CENTER#水平居中

alignment1.vert=xlwt.Alignment.VERT_CENTER#垂直居中

style1.alignment=alignment1#加入到style1样式中

#写数据

new_sheet.write(1,0,'2000',style1)#一定要带样式才能写入带样式的数据

new_sheet.write(1,1,apoints,style1)

new_sheet.write(2,0,'2001',style1)#单元格左上角的格子坐标为(0,0)

new_sheet.write(2,1,bpoints,style1)

new_sheet.write(3,0,'2002',style1)

new_sheet.write(3,1,cpoints,style1)

new_excel.save('d:/python_test/test3.xls')#另保存为新文件

表格test3、test2如下:

test2


test3
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容