第三方模块
脚本说明:尽在注释中
# -*- coding: utf-8 -*-
#导入xlwt (excel write) 模块
import xlwt
"""
多行注释,可以是三对单引号,也可以是三对双引号
"""
'''
设置单元格样式
'''
def set_style(name,height,bold=False):
# 初始化样式
style = xlwt.XFStyle()
# 为样式创建字体
font = xlwt.Font()
font.name = name # 'Times New Roman'
font.bold = bold
font.color_index = 4
font.height = height
# borders= xlwt.Borders()
# borders.left= 6
# borders.right= 6
# borders.top= 6
# borders.bottom= 6
style.font = font
# style.borders = borders
return style
#写excel
def write_excel():
#创建工作簿
f = xlwt.Workbook()
'''
创建第一个sheet:
sheet1
'''
#创建sheet
sheet1 = f.add_sheet(u'sheet1',cell_overwrite_ok=True)
row0 = [u'业务',u'状态',u'北京',u'上海',u'广州',u'深圳',u'状态小计',u'合计']
column0 = [u'机票',u'船票',u'火车票',u'汽车票',u'其它']
status = [u'预订',u'出票',u'退票',u'业务小计']
#生成第一行
for i in range(0,len(row0)):
sheet1.write(0,i,row0[i],set_style('Times New Roman',220,True))
#生成第一列和最后一列(合并4行)
i, j = 1, 0
while i < 4*len(column0) and j < len(column0):
#第一列
sheet1.write_merge(i,i+3,0,0,column0[j],set_style('Arial',220,True))
#最后一列"合计"
sheet1.write_merge(i,i+3,7,7)
i += 4
j += 1
sheet1.write_merge(21,21,0,1,u'合计',set_style('Times New Roman',220,True))
#生成第二列
i = 0
while i < 4*len(column0):
for j in range(0,len(status)):
sheet1.write(j+i+1,1,status[j])
i += 4
#保存文件,注意经测试只能支持生成xls文件,不支持xlsx文件
f.save('test2.xls')
#main程序入口
if __name__ == '__main__':
#执行写excel方法
write_excel()
write_merge方法:
write_merge(x, x + m, y, w + n, string, sytle)
x 表示行,
y 表示列,
m 表示跨行个数,
n 表示跨列个数,
string 表示要写入的单元格内容,
style 表示单元格样式。
其中,x,y,w,h,都是以0开始计算的。
➜ python ./writeExcel.py