xlwt以格式生成xls文件
参考: http://blog.sina.com.cn/s/blog_5357c0af01019gjo.html
http://www.programcreek.com/python/example/56293/xlwt.easyxf
import xlrd, xlwt
import re
import os
wbs = {}
SPLIT_NUM = 6
FN = 'yeah.xls'
SN = ''
header_style = xlwt.easyxf('font:bold on, height 280;align: horz center; border: top thin, right thin, bottom thin, left thin;')
header_height = xlwt.easyxf('font:height 500;')
title_style = xlwt.easyxf('font:bold on, height 220;border: top thin, right thin, bottom thin, left thin;')
title_height = xlwt.easyxf('font:height 500;')
cell_style = xlwt.easyxf('font:height 200;border: top thin, right thin, bottom thin, left thin;')
cell_height = xlwt.easyxf('font:height 400;')
CHARW = 650
with xlrd.open_workbook(FN) as book:
if SN:
sht = book.sheet_by_name(SN)
else:
sht = book.sheets()[0]
columns = [e.value for e in sht.row(0)]
for r in range(1, sht.nrows):
row = [e.value for e in sht.row(r)]
name = row[SPLIT_NUM]
sfz = row[1]
xm = row[2]
yh = row[7]
jtdm = row[3]
if name not in wbs:
wb = xlwt.Workbook()
ws = wb.add_sheet(name)
wbs[name] = {'wb':wb, 'ws':ws, 'r':4}
ws.write_merge(0, 0, 0, 4, '领卡签收表清单', header_style)
ws.write_merge(1, 1, 0, 1, '银行网点名称', header_style)
ws.write_merge(1, 1, 2, 4, yh, header_style)
ws.write_merge(2, 2, 0, 1, '集体名称', header_style)
ws.write_merge(2, 2, 2, 4, name, header_style)
ws.write_merge(3, 3, 0, 1, '集体代码', header_style)
ws.write_merge(3, 3, 2, 4, jtdm, header_style)
for r in range(4):
ws.row(r).set_style(header_height)
for col, e in enumerate([
('序号', CHARW*3), ('姓名', CHARW*5),
('身份证号码', CHARW*11),('领卡人联系电话', CHARW*8),
('领卡人签名', CHARW*6)]):
label = e[0]
width = e[1]
ws.write(4, col, label, title_style)
ws.col(col).width = width
ws.row(4).set_style(title_height)
else:
ws = wbs[name]['ws']
wbs[name]['r'] += 1
cr = wbs[name]['r']
ws.write(cr, 0, cr-4, cell_style)
ws.write(cr, 1, xm, cell_style)
ws.write(cr, 2, sfz, cell_style)
ws.write(cr, 3, '', cell_style)
ws.write(cr, 4, '', cell_style)
ws.row(cr).set_style(cell_height)
for k, v in wbs.items():
v['wb'].save(k+'.xls')
print('成功:'+k+'.xls')
xlwt以格式生成xls文件的更多相关文章
- flask使用pymysql连接MySQL,生成xls文件并下载到本地
版本一:将MySQL数据写入到excel(xsl)文件并下载到默认文件夹(一般问电脑的下载文件夹里面),并显示特效到前端页面. flask框架连接MySQL,我们使用pymsql这个工具,如下操作: ...
- protoc格式生成java文件
下载protoc.exe 地址:https://yvioo.lanzoui.com/i12opqs7q9g 下载好之后 ,把protoc文件和exe放在一个文件夹内 用记事本打开protoc,删掉包路 ...
- Python将数据写入excel或者txt,读入csv格式或xls文件,写入csv(写一行空一行解决办法)
1.写入excel,一开始不需要自己新建一个excel,会自动生成 attribute_proba是我写入的对象 import xlwt myexcel = xlwt.Workbook() sheet ...
- php中使用PHPExcel操作excel(xls)文件
读取中文的xls.csv文件会有问题,网上找了下资料,发现PHPExcel类库好用,官网地址:http://phpexcel.codeplex.com/ 1.读取xls文件内容 代码如下 复制代码 ...
- PHP - PHPExcel操作xls文件
读取中文的xls.csv文件会有问题,网上找了下资料,发现PHPExcel类库好用,官网地址:http://phpexcel.codeplex.com/ 1.读取xls文件内容 <?php // ...
- python3:xlrd、xlwt、xlutils处理excel文件
1.xlrd读取excel 请参考上篇博客https://www.cnblogs.com/shapeL/p/9075843.html 2.xlwt生成excel 安装下载:pip install xl ...
- php中使用PHPExcel读写excel(xls)文件的方法
首先从GitHub上下载 excel的相关类库 下载地址:https://github.com/PHPOffice/PHPExcel 以下是从excel中获取数据 <?php /** * * @ ...
- 【POI】使用POI 创建生成XLS,打开xls文件提示【此文件中某些文本格式可能已经更改,因为它已经超出最多允许的字体数。】
使用POI 创建生成XLS,打开xls文件提示[此文件中某些文本格式可能已经更改,因为它已经超出最多允许的字体数.] 原因: 是因为在POI处理xls的过程中,太多次调用了: HSSFFont fon ...
- python模块介绍- xlwt 创建xls文件(excel)
python模块介绍- xlwt 创建xls文件(excel) 2013-06-24磁针石 #承接软件自动化实施与培训等gtalk:ouyangchongwu#gmail.comqq 37391319 ...
随机推荐
- Java面试题——中级(下)
内部类和静态内部类的区别 内部类: 1.内部类中的变量和方法不能声明为静态的. 2.内部类实例化:B是A的内部类,实例化B:A.B b = new A().new B(). 3.内部类可以引用外部类的 ...
- 【H5-移动端开发】外部唤起本机APP的解决方法
太长时间没来博客园,原因很简单啊--太懒了!罪过罪过~ 最近公司的APP项目开始运行,采用的是原生框架+内嵌H5页面.作为一个菜鸡前端,开始入手学习移动端的界面制作加载性能优化.由于公司开始推广软件, ...
- 【机器学习】Iris Data Set(鸢尾属植物数据集)
注:数据是机器学习模型的原材料,当下机器学习的热潮离不开大数据的支撑.在机器学习领域,有大量的公开数据集可以使用,从几百个样本到几十万个样本的数据集都有.有些数据集被用来教学,有些被当做机器学习模型性 ...
- spring源码阅读(2)核心类介绍
(1).BeanFactory作为一个主接口不继承任何接口,暂且称为一级接口. (2).有3个子接口继承了它,进行功能上的增强.这3个子接口称为二级接口. (3).ConfigurableBeanFa ...
- jq图片展示插件highslide.js简单dom
今天用用了一款图片展示插件highslide.js,感觉用起来很是舒畅,几乎不用怎么写代码,只需要知道如何写参数就行了. 那么这么牛叉的插件我们该如何用哪,下面我就跟大家讲解一下. 一.引入 首先 ...
- enumerate给列表加序号
#coding=utf-8#给列表加上序号,enumerate(l1),默认从0开始l1=['money','house','joo']for item in enumerate(l1,1): #pr ...
- Python中time模块详解
Python中time模块详解 在平常的代码中,我们常常需要与时间打交道.在Python中,与时间处理有关的模块就包括:time,datetime以及calendar.这篇文章,主要讲解time模块. ...
- BZOJ 4372 烁烁的游戏
Description 背景:烁烁很喜欢爬树,这吓坏了树上的皮皮鼠.题意:给定一颗n个节点的树,边权均为1,初始树上没有皮皮鼠.烁烁他每次会跳到一个节点u,把周围与他距离不超过d的节点各吸引出w只皮皮 ...
- GotoAndPlay
10月3日,在杭州市西湖景区,一只小松鼠不停地接受一道道食物,花生.玉米.饼干,可谓来者不拒,憨态可掬的模样吸引了众多围观者...Description 小松鼠终于吃撑了,她决定逃离这个地方. 我 ...
- codeforces round #419 E. Karen and Supermarket
On the way home, Karen decided to stop by the supermarket to buy some groceries. She needs to buy a ...