python学习笔记(十八)python操作excel

python操作excel需要安装通过pip安装xlwt, xlrd这两个模块:

  pip install xlwt

  pip insall xlrd

操作excel ,写入excel:

 

 1 import xlwt
 2 book=xlwt.Workbook()#新建一个excel
 3 sheet=book.add_sheet('sheet1')##添加一个sheet页
 4 sheet.write(0,0,'姓名')
 5 sheet.write(0,1,'性别')
 6 sheet.write(0,2,'年龄')
 7 book.save('stu.xls')##不能用xlsx结尾,微软的不能用xlsx结尾office,wps的随便
 8 
 9 title = ['姓名','年龄','性别','分数']
10 stus = [['mary', 20, '', 89.9],
11         ['mary', 20, '', 89.9],
12         ['mary', 20, '', 89.9],
13         ['mary', 20, '', 89.9]]
14 
15 cols=0
16 for t in title:
17     sheet.write(0,cols,t)
18     cols+=1
19 row=1
20 for stu in stus:
21     new_cols=0:
22     for s in stu:
23         sheet.write(row,new_cols,s)
24         new_cols+=1
25     row+=1
26 book.save('stu.xls')

 读取excel:

 1 import xlrd
 2 book=xlrd.open_workbook('stu.xls')#打开一个excel
 3 sheet=book.sheet_by_index(0)#根据顺序获取sheet页
 4 #sheet=book.sheet_by_name('sheet1')#根据sheet页名字
 5 print(sheet.cell(0,0).value)#指定行和列获取数据
 6 print(sheet.cell(0,1).value)
 7 print(sheet.cell(0,2).value)
 8 print(sheet.cell(0,3).value)
 9 print(sheet.ncols)#获取excel里有多少列
10 print(sheet.nrows)#获取excel里有多少行
11 sheet.row_values(1)#取第几行的数据
12 for i in range(sheet.nrows):
13     print(sheet.row_values(i))#取第几行的数据
14 for i in range(sheet.ncols):
15     print(sheet.col_values(i))#取第几列的数据

修改excel:

1 from xlutils.copy import copy
2 import xlrd
3 book1=xlrd.open_workbook('stu.xls')
4 book2=copy(book1)#拷贝一份原来的excel
5 sheet=book2.get_sheet(0)#获取第几个sheet页
6 sheet.write(1,3,0)
7 sheet.write(1,0,'xiaohei')
8 book2.save('stu.xls')#可以写不同的名字,直接生成一个excel;如果写相同的名字,则直接修改,覆盖之前的内容。

 

posted @ 2018-01-30 15:27  飞鸟与新月  阅读(591)  评论(0编辑  收藏  举报