首先是保存excel的方法,可参照:

http://dzmlmszp.blog.163.com/blog/static/179271962014819111812531/

ok,进入正题。

现在我有一个table,如图:

图中的table可以是QTableWidget或QTableView

但是我需要隐藏最后一列,不要让用户看到,则在代码中加入:

ui->tableWidget->setColumnCount();

运行中效果如下:

现在问题来了,怎样才能将我的table保存为excel?

参照前面的博客,我自己重写了一个OdbcExcel类进行操作,先把代码贴上:

odbcexcel.h

 #ifndef ODBCEXCEL_H
#define ODBCEXCEL_H #include <QObject>
#include <QStringList>
#include <QSqlQuery>
#include <QSqlDatabase>
#include <QSqlError>
#include <QTableView> /**
* @brief The OdbcExcel class
* @author 郑泽桐
*/ class OdbcExcel
{
public:
OdbcExcel();
//将数据保存为excel
bool static save(QString filePath,QStringList headers,QList<QStringList> data,QString comment="");
//将QTableView保存为excel
bool static saveFromTable(QString filePath,QTableView *tableView,QString comment="");
//获取错误信息
QString static getError(){return error;}
private:
void static printError( QSqlError error);
bool static insert(QSqlQuery& query, QString sheetName, QStringList slist);
static QString error;
}; #endif // ODBCEXCEL_H

odbcexcel.cpp

 #include "odbcexcel.h"
#include <QDebug> OdbcExcel::OdbcExcel()
{
}
QString OdbcExcel::error; bool OdbcExcel::save(QString filePath, QStringList headers, QList<QStringList> data,QString comment)
{
QString sheetName = "Sheet1"; QSqlDatabase db = QSqlDatabase::addDatabase("QODBC","excelexport");
if( !db.isValid())
{
error="数据库驱动异常";
return false; //! type error
} QString dsn = "DRIVER={Microsoft Excel Driver (*.xls)};"
"DSN='';FIRSTROWHASNAMES=1;READONLY=FALSE;CREATE_DB=\""+filePath+"\";DBQ="+filePath;
db.setDatabaseName( dsn); // open connection
if( !db.open())
{
error="无法打开数据库";
return false; //! db error
} QSqlQuery query(db);
QString sql; // drop the table if it's already exists
sql = QString("DROP TABLE [%1]").arg(sheetName);
query.exec( sql);
//create the table (sheet in Excel file)
sql = QString("CREATE TABLE [%1] (").arg(sheetName);
foreach (QString name, headers) {
sql +=QString("[%1] varchar(200)").arg(name);
if(name!=headers.last())
sql +=",";
}
sql += ")";
query.prepare( sql);
if( !query.exec()) {
OdbcExcel::printError( query.lastError());
db.close();
return false;
}
foreach (QStringList slist, data) {
insert(query,sheetName,slist);
} if(!comment.isEmpty())
{
QStringList slist;
slist<<comment;
for(int i=,n=headers.size()-;i<n;i++)
{
slist<<"";
}
insert(query,sheetName,slist);
} db.close();
return true;
} bool OdbcExcel::saveFromTable(QString filePath,QTableView *tableView, QString comment)
{
QAbstractItemModel* model=tableView->model();
const int column=model->columnCount();
const int row=model->rowCount(); //header
QStringList headers;
for(int i=;i<column;i++)
{
//隐藏列
if(tableView->isColumnHidden(i))
continue;
headers<<model->headerData(i,Qt::Horizontal).toString();
} //data
QStringList list;
QList<QStringList> data;
for(int i=;i<row;i++)
{
if(model->index(i,).data().isNull())
continue;
list.clear();
for(int j=;j<column;j++){
//隐藏列
if(tableView->isColumnHidden(j))
continue;
list<<model->index(i,j).data().toString();
}
data<<list;
}
return OdbcExcel::save(filePath,headers,data,comment);
} void OdbcExcel::printError(QSqlError error)
{
QString sqlerr = error.text();
error=sqlerr;
qCritical()<<sqlerr;
} bool OdbcExcel::insert(QSqlQuery &query, QString sheetName, QStringList slist)
{
QString sSql = QString("INSERT INTO [%1] VALUES(").arg( sheetName);
for(int i=,n=slist.size();i<n;i++)
{
sSql+=QString(":%1").arg(i);
if(i!=n-)
sSql+=",";
else
sSql+=")";
}
query.prepare( sSql);
for(int i=,n=slist.size();i<n;i++)
{
query.bindValue(QString(":%1").arg(i),slist.at(i));
}
if( !query.exec()) {
printError( query.lastError());
return false;
}
return true;
}

接下来就是调用了,save按键的click事件:

   QFileDialog dlg;
dlg.setAcceptMode(QFileDialog::AcceptSave);
// Qt 5
dlg.setDirectory(QStandardPaths::writableLocation(QStandardPaths::DesktopLocation));
// Qt 4
// dlg.setDirectory(QDesktopServices::storageLocation(QDesktopServices::DesktopLocation));
dlg.setNameFilter("*.xls");
dlg.selectFile(QDate::currentDate().toString("yyyy-MM-dd.xls"));
if(dlg.exec()!= QDialog::Accepted)
return;
QString filePath=dlg.selectedFiles()[];
if(OdbcExcel::saveFromTable(filePath,ui->tableWidget,"注释:无")) {
QMessageBox::information(this,tr("提示"),tr("保存成功"));
}
else{
QString msg="保存失败!\n\r"+OdbcExcel::getError();
QMessageBox::critical(this,tr("错误"),tr(msg.toUtf8()));
}

看一下效果:

隐藏的列也不会显示出来。

调用OdbcExcel::saveFromTable函数,就可以将QTableWidget或QTableView保存为excel。

另外,我提供了save函数,可以直接将表头(QString headers)以及数据(QList<QStringList> data)保存为excel。

转载请标明出处:http://www.cnblogs.com/ztzheng/p/4172847.html

Qt将表格table保存为excel(odbc方式)的更多相关文章

  1. html table表格导出excel的方法 html5 table导出Excel HTML用JS导出Excel的五种方法 html中table导出Excel 前端开发 将table内容导出到excel HTML table导出到Excel中的解决办法 js实现table导出Excel,保留table样式

    先上代码   <script type="text/javascript" language="javascript">   var idTmr; ...

  2. 【HTML5版】导出Table数据并保存为Excel

    首发我的博客 http://blog.meathill.com/tech/js/export-table-data-into-a-excel-file.html 最近接到这么个需求,要把<tab ...

  3. asp.net将内容导出到Excel,Table表格数据(html)导出EXCEL

    代码: /// <summary> /// HTML Table表格数据(html)导出EXCEL /// </summary> /// <param name=&quo ...

  4. qt QTableWidget&&QTableView 导出数据到excel

    通常情况下,我们在开发过程中比较常用的方法是将表格的数据到处到excel文件.我也在这个点上头疼了很长时间,不过功夫不负苦心人,最终还是勉强达到效果,为了后面再次用到时不手忙脚乱现在将方法寄存在此,如 ...

  5. [转]qt QTableWidget&&QTableView 导出数据到excel

    转自http://blog.csdn.net/fairystepwgl/article/details/54576372 注意:由于在qt导出的过程中分为QTableWidget导出文件到excel和 ...

  6. Qt实现表格控件-支持多级列表头、多级行表头、单元格合并、字体设置等

    目录 一.概述 二.效果展示 三.定制表头 1.重写数据源 2.重写QHeaderView 四.设置属性 五.相关文章 原文链接:Qt实现表格控件-支持多级列表头.多级行表头.单元格合并.字体设置等 ...

  7. html table 保存到excel中

    引用:HTML中的table导出为Excel文件 <!DOCTYPE html> <html lang="en"> <head> <met ...

  8. Qt实现表格树控件-支持多级表头

    目录 一.概述 二.效果展示 三.实现方式 四.多级表头 1.数据源 2.表格 3.QStyledItemDelegate绘制代理 五.测试代码 六.相关文章 原文链接:Qt实现表格树控件-支持多级表 ...

  9. HTML Table导出为Excel的方法

    HTML Table导出为Excel的方法: 直接上源码 <html> <head> <meta http-equiv="Content-Type" ...

随机推荐

  1. C++ Primer 5th 第3章 字符串、向量和数组

    *****代码在Debian g++ 5.40 / clang++ 3.8(C++11)下编写调试***** 本章主要是关于字符串.数组的内容,以及一些简单的容器知识. 1.using的声明 usin ...

  2. web标准(复习)--4 纵向导航菜单及二级弹出菜单

    今天我们开始学习纵向导航菜单及二级弹出菜单,包含以下内容和知识点: 纵向列表 标签的默认样式 css派生选择器 css选择器的分组 纵向二级列表 相对定位和绝对定位 一.纵向列表纵向列表或称为纵向导航 ...

  3. 消息机制 - Windows程序设计(SDK)004

    消息机制 让编程改变世界 Change the world by program 内容节选: 我们来回顾一下,窗口是怎么从代码中诞生出来的? 1. 首先我们是通过给 WNDCLASS 窗口类结构各个成 ...

  4. 容器 vector :为何要有reserve

    关于STL容器,最令人称赞的特性之一就是是只要不超过它们的最大大小,它们就可以自动增长到足以容纳你放进去的数据.(要知道这个最大值,只要调用名叫max_size的成员函数.)对于vector和stri ...

  5. Android学习笔记--AlertDialog应用

    1. 自定义实现带图标的TextView IconTextView.java package com.evor.andtest; import android.content.Context; imp ...

  6. scala 入门(1)

    大数据“火”的有段日子了,原来打算学习hadoop…… 后知道spark要比hadoop更牛, 故而转学spark.其原码为scala所写,为了更好的研究spark,故又开始学习scala. 将自己所 ...

  7. CCI_chapter 19 Moderate

    19 1  Write a function to swap a number in place without temporary variables void swap(int &a, i ...

  8. 自制单片机之四……LCD1602的驱动

    LCD1602已很普遍了,具体介绍我就不多说了,市面上字符液晶绝大多数是基于HD44780液晶芯片的,控制原理是完全相同的,因此HD44780写的控制程序可以很方便地应用于市面上大部分的字符型液晶.字 ...

  9. dedecms 在php7.0无法安装

    dedecms 需要mysql扩展的支持!而php7.0已废弃mysql扩展.所以我讲7.0改回了5.6然后就可以顺利安装了. 总结了一个经验:没有绝对实力,不要尝试新东西

  10. Android数据库信息显示在listview上

    Key Points: 1.使用SimpleCursorAdapter将Android数据库信息显示在listview上 adapter = new SimpleCursorAdapter(this, ...