求助,QT根据excel里的excel中数据生成图表表

20627人阅读
如果你在做一个报表类的程序,可能将内容导出为Excel文件是一项必须的功能。之前使用MFC的时候我就写过一个类,用于将grid中的数据导出为Excel文件。在使用了QtSql模块后,我很容易的将这个类改写应用在Qt程序中。类的名字叫&ExportExcelObject&。使用起来很简单:
// 1. declare an object
// & fileName Excel 文件路径
// & sheetName Excel 工作表(sheet)名称
// & tableView 需要导出的QTableView指针
ExportExcelObject obj(fileName, sheetName, tableView);
// 2. define fields (columns) to the Excel sheet file
// & 第1个参数是QTableView的列
// & 第2个参数是对应该列的Excel sheet中的列名
// & 第3个参数是该列的类型,可以使用char(x) (x最大255),int,datetime, 等
obj.addField(1, tr("name"), "char(60)");
obj.addField(2, tr("ID"), "int");
obj.addField(3, tr("time"), " datetime ");
// 3. 该类有特定的SIGNAL用于连接一个progress控件,可以显示导出进度
connect(&obj, SIGNAL(exportedRowCount(int)), progressBar, SLOT(setValue(int)));
// 4. do the work
int retVal = obj.export2Excel();
if(retVal & 0)
{//something wrong
&&&&&&&& 那么这个类是怎样实现的呢?
1.将Excel文件当成是一个数据库
使用MS的ODBC或ADO都可以将Excel文件当做一个数据库,那么我们只需要使用下面这个DSN连接串去创建并连接至该Excel文件:
QString dsn = QString("DRIVER={Microsoft Excel Driver (*.xls)};DSN=''; FIRSTROWHASNAMES=1;;CREATE_DB=/"%1/";DBQ=%2").
arg(excelFilePath).arg(excelFilePath);
2.将Excel的工作表(sheet)当成是一个数据库表
可以使用SQL语句&CREATE TABLE& 去创建一个工作表。
3.向表中插入数据
使用SQL的&INSERT&语句插入数据。
4.Unicode支持
是的,列名和数据都支持Unicode。
我写了个例子用于演示这个类()。这个程序在WinXP/Vista/7都可正常运行。这个程序并不需要你的电脑上安装了Excel,因为{Microsoft Excel Driver (*.xls)}从Windows 2000开始就是系统自带支持的。
&&相关文章推荐
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:159569次
积分:1936
积分:1936
排名:千里之外
原创:24篇
评论:280条
(1)(2)(3)(2)(1)(1)(2)(1)(2)(5)(2)(1)(1)本帖子已过去太久远了,不再提供回复功能。

我要回帖

更多关于 excel如何生成图表 的文章

 

随机推荐