Qt 导出EXCEL文件

QString fileName = QFileDialog::getSaveFileName(this, tr("Excel file"), qApp->applicationDirPath(),tr("Excel Files (*.xls)"));

if (fileName.isEmpty())

return;

if (excel(fileName))//调用导出Excel方法

{

QMessageBox::about(this, QStringLiteral("提示"),  QStringLiteral("Excel文件 导出完成") );

QSqlDatabase::removeDatabase("excelexport");

}

bool RecordDlg::excel(QString fileName )

{

QSqlDatabase db = QSqlDatabase::addDatabase("QODBC", "excelexport");

if(!db.isValid())

{

return false;

}

QString dsn = QString("DRIVER={Microsoft Excel Driver (*.xls)};DSN=‘‘;FIRSTROWHASNAMES=1;READONLY=FALSE;CREATE_DB=\"%1\";DBQ=%2").arg(fileName).arg(fileName);

db.setDatabaseName(dsn);

if(!db.open())

{

QMessageBox::about(this, QStringLiteral("提示"),  QStringLiteral("Excel文件 导出失败") );

QSqlDatabase::removeDatabase("excelexport");

return false;

}

QSqlQuery query(db);

QString strSql=QObject::tr("drop table [%1]").arg(QStringLiteral("人脸识别记录"));

query.exec(strSql);

strSql = QObject::tr("CREATE TABLE [%1]([%2] char(100),[%3] char(100),[%4] char(100),[%5] char(100),[%6] char(100),[%7] char(100),[%8] char(100),[%9] char(100))")

.arg(QStringLiteral("人脸识别记录"))

.arg(QStringLiteral("序号"))

.arg(QStringLiteral("时间"))

.arg(QStringLiteral("位置"))

.arg(QStringLiteral("工号"))

.arg(QStringLiteral("姓名"))

.arg(QStringLiteral("部门编号"))

.arg(QStringLiteral("状态"))

.arg(QStringLiteral("图片"));

qDebug()<<strSql;

query.prepare(strSql);

if(!query.exec())

{

QMessageBox::about(this, QStringLiteral("提示"),  QStringLiteral("Excel文件 导出失败") );

db.close();

QSqlDatabase::removeDatabase("excelexport");

return false;

}

for each(RecordItem var in vecRecord)

{

QString index = QString::number(var.index);

QString dTime;

GetRecordTime(var.dTime,&dTime);

QString szCamPos=var.szCamPos;

QString szJobNum=var.szJobNum;

QString szName =var.szName;

QString szDept=var.szDept;

QString status;

switch(var.status) {

case AlarmType::NORMAL:

status=QStringLiteral("正常");

break;

case AlarmType::HANDLED:

status=QStringLiteral("已处理");

break;

case AlarmType::ABNORMAL:

status=QStringLiteral("异常");

break;

default:

status=QStringLiteral("未知");

break;

}

QString szImgName=var.szImgName;

//query.prepare(strSql);

strSql=QObject::tr("insert into %1 values(‘%2‘,‘%3‘,‘%4‘,‘%5‘,‘%6‘,‘%7‘,‘%8‘,‘%9‘)")

.arg(QStringLiteral("人脸识别记录"))

.arg(index)

.arg(dTime)

.arg(szCamPos)

.arg(szJobNum)

.arg(szName)

.arg(szDept)

.arg(status)

.arg(szImgName);

qDebug()<<strSql;

if(!query.exec(strSql))

{

qDebug()<<query.lastError();

qDebug()<<query.lastQuery();

QMessageBox::about(this, QStringLiteral("提示"),  QStringLiteral("Excel文件 导出失败") );

db.close();

QSqlDatabase::removeDatabase("excelexport");

return false;

}

}

return true;

}

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-08-28 11:04:49

Qt 导出EXCEL文件的相关文章

PHP从数据库导出EXCEL文件

参考博客链接:http://www.cnblogs.com/huangcong/p/3687665.html 我的程序代码 原生导出Excel文件 <?phpheader('Content-type: text/html; charset=utf-8');header("Content-type:application/vnd.ms-excel");header("Content-Disposition:filename=test.xls"); $conn =

TXLSReadWriteII2版本导出Excel文件:

//TXLSReadWriteII2版本导出Excel文件: procedure TForm1.N1Click(Sender: TObject); var i: Integer; aSaveDialog: TSaveDialog; aFileName, aStampTime: AnsiString; aXlsObj: TXLSReadWriteII2; p: PDataRec; begin aSaveDialog := TSaveDialog.Create(Self); try aSaveDia

使用Open Xml按模版导出Excel文件(下)

(3)将数据写入Excel 把数据写入到Excel文件是本文的关键技术.这里需要用到OpenXml.在Sdk里已经提供了足够的文件操作方法,我们就调用这些方法,将数据源的数据写到文件中. 首先我们定义了一些工具类,用于读取单元格的行列值. 在Excel中,每个单元格都有一个地址:如B3表示第二行第三列的格子,在Utility中的GetRowIndex和GetColumnIndex就是输入字符串”B3”,返回Int类型的索引2 和3.还有输入“B3”,返回列的字母“B”等等. 在WorkSheet

PHPExcel导出Excel文件

error_reporting(0); require_once 'phpexcel/PHPExcel.php'; require_once 'phpexcel/PHPExcel/IOFactory.php'; $objPHPExcel = new PHPExcel(); $objPHPExcel->getProperties()->setCreator("BillHong") ->setLastModifiedBy("BillHong")//创建

Java web中不同浏览器间导出Excel文件名称乱码问题解决方案

问题描述: 对于不同浏览器存在对中文编码格式问题,从而在导出Excel文件时,中文文件名出现乱码的情况,即在程序中给要导出的文件指定一个中文名字时,在浏览器上出现的下载框中的文件名出现了乱码,解决如下: 解决方案: [java] view plain copy Date dt=new Date();//如果不需要格式,可直接用dt,dt就是当前系统时间 DateFormat df = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");//设置显示格

PHP导出excel文件,第一步先实现PHP模板导出不带数据

今天继续研究PHP导出excel文件,把复杂的事情简单化,一步步实现功能,首先实现模板文件的导出,随后再实现写入数据后导出,最终实现功能,这是基本思路.中间可以加一步,先自己写入数据导出试试,随后再数据库导入.我首先把程序提交到自建的eubexcel.php文件,选用post提交,导出excel文件的程序在这个页面里书写,参考昨天下载的PHPExcel-1.8组件里的参考文档,先部署导出excel,具体代码如下 <?php error_reporting(E_ALL);ini_set('disp

使用Open Xml按模版导出Excel文件(上)

完整内容请参见我的网站 http://www.iyummy.com.cn/Blog/Detail/3 我们在做应用系统中经常需要将数据库中的数据导出成为Excel文件.如果是要导出报表的话,最好是能够根据定义好的模版生成一个美观的Excel. 以前要生成有样式的Excel.一般是使用Xml形式的Excel修改,或者使用Excel的Api.前者要修改样式的话特别麻烦,后者在Asp.net里会起很多进程. 庆幸的是从office 2007开始,微软使用了OpenXml来定义office的文件.使用r

JQGrid导出Excel文件

系列索引 Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引 Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数.ColModel API.事件及方法 Web jquery表格组件 JQGrid 的使用 - 5.Pager翻页.搜索.格式化.自定义按钮 Web jquery表格组件 JQGrid 的使用 - 6.准备工作 & Hello JQGrid Web jquery表格组件 JQGrid 的使用 - 7.查询数据.编辑数据.删除数据

(C#)利用Aspose.Cells组件导入导出excel文件

Aspose.Cells组件可以不依赖excel来导入导出excel文件: 导入: [csharp] view plain copy print? public static System.Data.DataTable ReadExcel(String strFileName) { Workbook book = new Workbook(); book.Open(strFileName); Worksheet sheet = book.Worksheets[0]; Cells cells =