下面代码使用web.py框架,其他框架都大同小异。

# coding: utf-

import web
import json
import datetime
import xlwt
import StringIO # 如果不在前端调用接口,如下web.py框架的urls和app、render可以省略
urls = ( # web框架的路由
'/index','Index',
'/home','Home',
)
app = web.aplication(urls, globals()) # 注册应用
render = web.template.render('template') # 模板,注意路径 #如果不在前端调用接口,如上web.py框架的urls和app、render可以省略 # 这个类,仅仅返回一个前端页面,页面里面的按钮使用ajax来请求下面其他接口,这个html内容我就不写了
class Index(object):
def GET(self):
return render.mubanmingzi({}) # 生成Excel文件
class Excel(object):
def GET(self):
web.header('Content-type', 'applicationvnd.ms-excel') # 请求头,返回指定内容
web.header('Transfer-Encoding', 'chunked')
namedate = str(datetime.date.today())
# 设定用户浏览器生成excel文件的名字
web.header('Content-Disposition', 'attachment:filname={0}'.format('Excel表' + namedate + 'xls')
# 以上都不重要,仅供参考,如下是使用python的第三方库xlwt来生成xecel文件
wb = xlwt.Workbook(encoding='utf-8') # 创建工作簿对象
ws = wb.add_sheet('sheet') # 要写入的sheet的名字,就是excel的工作台,不懂的可以去百度
bs = xlwt.Borders() # 创建边框对象,用来指定表格边框的样式(粗细,虚线实现,颜色等)
bs.left = xlwt.Borders.THIN # 左侧实线
bs.right = xlwt.Borders.THIN # 右侧实线
bs.top = xlwt.Borders.THIN # 上边实线
bs.bottom = xlwt.Boeders.THIN # 下边实线
bs.left_colour = ox40 # 颜色
style = xlwt.XFStyle() # 创建样式对象
style.borders = bs # 将设置好的bs样式给style对象 # 下面开始往创建好的excel对象里面写入数据
# 我们将地0行的前5个格合并居中,用来写入注意事项
# 前两个0表示从0行到0行这个范围,第3个0表示从第0列,4表示到第5列(行列索引都从0开始),最后一个值就是要写入的内容了)
ws.write_merge(,,,,'这是写入的内容')
# 设置表头
for i in range():
ws.write(, i, '标题{0}'.format(str(i))) # 5格,1表示第二行,i表示第二行的前5格,标题0-标题4没别为每行内容
# 下面类似,写入内容
row = # 第三行开始写内容数据
for i in range(): # 写入10行
ws.write(row, , '内容1', style) # 内容写入,边框样式生效
ws.write(row, , '内容2', style)
ws.write(row, , '内容3', style)
ws.write(row, , '内容4', style)
ws.write(row, , '内容5', style)
row += # 指定每列的宽度
ws.col().width = # 第0列
ws.col().width = # 第1列
ws.col().width = # 将数据流保存到本地磁盘
sio = StringIO.StringIO() # 创建数据流
web.save(sio) # 注意,这里保存的是数据流,不是文件名
sio.seek() # 光标,从0的位置开始写入
return sio.getvalue() # 将生成文件特效返回到浏览器,其实文件已经保存到电脑的下载文件内了。

python自动生成excel(xlwt库)的更多相关文章

  1. python自动生成excel报表

    1.将SQL语句查询的内容,直接写入到excel报表中,以下为全部脚本.要求:此版本必须运维在windows平台,并且安装了excel程序,excel版本不限. python版本为2.7 if b 判 ...

  2. python自动生成Docx(docxtpl库)

    python这个库很有用,可以格式化生成报告等. 其他内容请点此处,下面只写docxtpl的功能代码. # coding: utf-8 import web # 我们用的webpy框架 import ...

  3. 从用python自动生成.h的头文件集合和类声明集合到用python读写文件

    最近在用python自动生成c++的类.因为这些类会根据需求不同产生不同的类,所以需要用python自动生成.由于会产生大量的类,而且这些类是变化的.所以如果是在某个.h中要用include来加载这些 ...

  4. 利用python自动生成verilog模块例化模板

    一.前言 初入职场,一直忙着熟悉工作,就没什么时间更新博客.今天受“利奇马”的影响,只好宅在家中,写写技术文章.芯片设计规模日益庞大,编写脚本成了芯片开发人员必要的软技能.模块端口动不动就几十上百个, ...

  5. Python自动生成代码工具

    项目中有一个需求,对一个基类而言,拥有一个比较方法和拷贝方法,某些地方需要频繁地对这两个方法进行调用.对于所有子类而言,需要重写这两个方法,并在其中维护类内一些成员变量.例如有一个变量m_iMyVal ...

  6. 详解python操作生成excel表格,并且填充数据

    最近在研究python操作excel表格的问题,首先读取excel表格觉得平时用的多,不怎么有难度,就是pyhon生成excel表格的时候,平时不怎么用,所以重点研究了一下,现总结如下: 1.首先用到 ...

  7. 使用python自动生成docker nginx反向代理配置

    由于在测试环境上用docker部署了多个应用,而且他们的端口有的相同,有的又不相同,数量也比较多,在使用jenkins发版本的时候,不好配置,于是想要写一个脚本,能在docker 容器创建.停止的时候 ...

  8. python 自动生成C++代码 (代码生成器)

    python 代码自动生成的方法 (代码生成器) 遇到的问题 工作中遇到这么一个事,需要写很多C++的底层数据库类,但这些类大同小异,无非是增删改查,如果人工来写代码,既费力又容易出错:而借用pyth ...

  9. python自动生成bean类

    近期在学习python,一直在和java做对比,目前没有发现有通过字段自动生成getter setter方法,故此自己写了一个类,可以通过__init__方法传入类名和字段数组,再调用内部的方法,就可 ...

随机推荐

  1. java中图片地址base64编码的相互转换

    public class Base64Url { /** * 将base64编码字符串转换为图片 * @param imgStr: base64编码字符串 * @param path: 图片路径-具体 ...

  2. docker MySQL官方版本使用记录

    docker MySQL官方版本使用记录 使用记录 拉取官方镜像:docker pull mysql 运行镜像:docker run --name mysql -p 3306:3306 -e MYSQ ...

  3. python-Web-django-图表统计

    下载highchart插件包,放在static下 <script src="/static/highcharts/highcharts.js"></script& ...

  4. 【VS开发】VC++ 获取系统时间、程序运行时间(精确到秒,毫秒)的五种方法

    1.使用CTime类(获取系统当前时间,精确到秒) CString str; //获取系统时间 CTime tm; tm=CTime::GetCurrentTime();//获取系统日期 str=tm ...

  5. 【VS开发】关于在CFormView中实现CListCtrl控件的注意事项

    [VS开发]关于在CFormView中实现CListCtrl控件的注意事项 标签(空格分隔): [VS开发] 今天调试中发现了一项非常令人恼怒的事情,本来早都知道在CFormView中没有了像在对话框 ...

  6. C学习笔记-预备知识

    计算机结构组成 CPU(中央处理器)(控制器+运算器) 存储器(内存+外存) 输出设备 输入设备 计算机系统组成 硬件系统 主机 中央处理器 运算器 控制器 内存储器 只读存储器 随机存储器 外部设备 ...

  7. nRF5 SDK Bootloader and DFU moudles(2)

    镜像的验证 在执行设备固件更新之前,应验证新映像. 在传输实际固件(预验证)之前,可以检查某些信息(例如,兼容性). 其他信息,例如图像的散列,应在传输(验证后)后进行验证. Init packet ...

  8. Apache——开启个人用户主页功能

    个人主页功能分为不加密和加密两种 不加密: 先来建立几个用户,我这是建了两个 例:命令为:useradd  qiyuan 然后输入:passwd qiyuan,改一下密码 我们看一下家目录下面: 已经 ...

  9. Swagger2异常:Illegal DefaultValue null for parameter type integer java

    一.异常分析: Illegal DefaultValue null for parameter type integer`和`NumberFormatException: For input stri ...

  10. ZOJ Problem Set - 1006

    注意:A的ascii为65,a为97就行了 其他没什么,略过. 代码参看: http://my.oschina.net/dianpaopao/blog/124545