码迷,mamicode.com
首页 > 编程语言 > 详细

python处理excel(二):写

时间:2016-05-14 17:04:55      阅读:294      评论:0      收藏:0      [点我收藏+]

标签:

代码参考自zhoujie。函数接口可参考该blog

基本的write函数接口很简单:

新建一个excel文件

file = xlwt.Workbook() (注意这里的Workbook首字母是大写)

新建一个sheet

table = file.add_sheet(‘sheet_name‘)

写入数据table.write(行,列,value)

table.write(0,0,‘test‘)

如果是写入中文,则要用u‘汉字‘的形式。比如

table.write(0,0, u‘汉字‘)

合并单元格:

table.write_merge(x, x + m, y, y + n, string, style)

x表示行,y表示列,m表示跨行个数,n表示跨列个数,string表示要写入的单元格内容,style表示单元格样式。

 

 

 1 #coding=utf8
 2 ‘‘‘
 3 设置单元格样式
 4 ‘‘‘
 5 import xlwt, xlrd
 6 
 7 def set_style(name,height,bold=False):
 8     style = xlwt.XFStyle()  # 初始化样式
 9 
10     font = xlwt.Font()  # 为样式创建字体
11     font.name = name # ‘Times New Roman‘
12     font.bold = bold
13     font.color_index = 4
14     font.height = height
15 
16     # borders= xlwt.Borders()
17     # borders.left= 6
18     # borders.right= 6
19     # borders.top= 6
20     # borders.bottom= 6
21 
22     style.font = font
23     # style.borders = borders
24 
25     return style
26 
27 
28 #写excel
29 def write_excel():
30     f = xlwt.Workbook() #创建工作簿
31 
32     ‘‘‘
33     创建第一个sheet:
34         sheet1
35     ‘‘‘
36     sheet1 = f.add_sheet(usheet1,cell_overwrite_ok=True) #创建sheet
37     row0 = [u业务,u状态,u北京,u上海,u广州,u深圳,u状态小计,u合计]
38     column0 = [u机票,u船票,u火车票,u汽车票,u其它]
39     status = [u预订,u出票,u退票,u业务小计]
40 
41     #生成第一行
42     for i in range(0,len(row0)):
43         sheet1.write(0,i,row0[i],set_style(Times New Roman,220,True))
44 
45     #生成第一列和最后一列(合并4行)
46     i, j = 1, 0
47     while i < 4*len(column0) and j < len(column0):
48         sheet1.write_merge(i,i+3,0,0,column0[j],set_style(Arial,220,True)) #第一列
49         sheet1.write_merge(i,i+3,7,7) #最后一列"合计"
50         i += 4
51         j += 1
52 
53     sheet1.write_merge(21,21,0,1,u合计,set_style(Times New Roman,220,True))
54 
55     #生成第二列
56     i = 0
57     while i < 4*len(column0):
58         for j in range(0,len(status)):
59             sheet1.write(j+i+1,1,status[j])
60         i += 4
61 
62     f.save(demo1.xls) #保存文件.这里如果是.xlsx的话会打不开。
63 
64 if __name__ == __main__:
65     #generate_workbook()
66     #read_excel()
67     write_excel()

注意:最终生成的文件如果是demo1.xlsx的话打不开,.xls就没问题。

如果对一个单元格重复操作,会引发error。所以在打开时加cell_overwrite_ok=True解决

table = file.add_sheet(‘sheet name‘,cell_overwrite_ok=True)

 

生成的demo1.xls效果如下。

技术分享

 

python处理excel(二):写

标签:

原文地址:http://www.cnblogs.com/forcheryl/p/5492804.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!