一直都是使用 C/C++ 来编写 CGI ,最近碰到一个需要将数据库记录导出到 excel 文件的需求,在 C/C++ 下基本上没有什么好的解决办法,尤其是在 linux 下,但是时下流行的各种脚本语言却对 excel 文件的操作有不错的支持,比如 perl , python 等( php 下所能找到的组件都会或多或少有些问题,比如单元格内字节 255 限制, excel2003 版本限制等),基于 dui 语言的熟悉程度将 python 嵌入到 C++ 的解决思路也就形成了。
Python 下选用的组件是 pyexcelerator ,在 python 的官方网站上就能获得,安装过程这里就掠过了,下面把重要的代码片段贴出来。
excel.py
#-*-coding:gbk-*-
from pyExcelerator import *
def _toUnicode(s, enc):
return unicode(s, enc)
def writeArray(ary, f='array.xls', s='sheet', enc='gbk'):
w = Workbook()
ws = w.add_sheet(_toUnicode(s, enc))
for i in range(len(ary)):
for j in range(len(ary[i])):
style = XFStyle()
fnt = Font()
fnt.height = i * 20
style.font = fnt
ws.write(i, j, _toUn