Qt 解析EXcel文件
写代码需要将excel中的文件导入到数据库中
网上找到以为大神写的,但是当初没有保存,也没有找到
我几乎是原分不动拔下来的,希望大神莫怪
void AddDialog::readExcel(QString url)
{
QAxObject excel("Excel.Application");
excel.setProperty("Visible",true);
QAxObject *work_books = excel.querySubObject("WorkBooks");
work_books->dynamicCall("Open (const QString&)",QString(url));
QVariant title_value = excel.property("Caption"); //获取标题信息
// qDebug()<<"读取Excel标题为:"<<title_value;
QAxObject *work_book = excel.querySubObject("ActiveWorkBook");
QAxObject *work_sheets = work_book->querySubObject("Sheets"); //Sheets也可以换用WorkSheets
int sheet_count = work_sheets->property("Count").toInt(); //获取工作表数目
// qDebug()<<"当前工作表数目为:"<<sheet_count;
exceltip = new Excel(this);
for(int k=1;k<=sheet_count;k++)
{
QAxObject *work_sheet = work_book->querySubObject("Sheets(int)",k); //Sheets(int)也可以用Worksheets(int)
QString work_sheet_name = work_sheet->property("Name").toString(); //获取工作表名称
QString message = QString("Sheet")+QString::number(k,10)+QString("name");
// qDebug()<<message<<work_sheet_name;
if(sheet_count>0)
{
QAxObject *work_sheet = work_book->querySubObject("Sheets(int)",k);
QAxObject *used_range = work_sheet->querySubObject("UsedRange");
QAxObject *rows = used_range->querySubObject("Rows");
// QAxObject *columns = used_range->querySubObject("Columns");
int row_start = used_range->property("Row").toInt(); //获取起始行
int columns_start = used_range->property("Column").toInt(); //获取起始列
int row_count = rows->property("Count").toInt(); //获取行数
// int column_count = columns->property("Count").toInt(); //获取列数
exceltip->show();
ui->pushButton_Cancle->setEnabled(false);
ui->pushButton_close->setEnabled(false);
ui->pushButton_save->setEnabled(false);
ui->pushButton_Excel->setEnabled(false);
ui->pushButton_update->setEnabled(false);
exceltip->setcount(row_count-1,work_sheet_name);
for(int i=row_start+1;i<=row_count;i++)
{
/***********************************
* 数据解析函数函数
* 将Excel中的数据分条取出
* 的别值得注意的是
* 由于数据主码是一当前时间为主码
* 所以要调用延时函数延时1秒
* 防止数据主码相同为数据加载失败
****************************************************************************************************************/
QAxObject *cell[13];
QVariant cell_value[13]; cell[0] = work_sheet->querySubObject("Cells(int,int)",i,columns_start+0);
cell_value[0] = cell[0]->property("Value"); //获取单元格内容 cell[1] = work_sheet->querySubObject("Cells(int,int)",i,columns_start+1);
cell_value[1] = cell[1]->property("Value"); cell[2] = work_sheet->querySubObject("Cells(int,int)",i,columns_start+2);
cell_value[2] = cell[2]->property("Value"); cell[3] = work_sheet->querySubObject("Cells(int,int)",i,columns_start+3);
cell_value[3] = cell[3]->property("Value"); cell[4] = work_sheet->querySubObject("Cells(int,int)",i,columns_start+4);
cell_value[4] = cell[4]->property("Value"); cell[5] = work_sheet->querySubObject("Cells(int,int)",i,columns_start+5);
cell_value[5] = cell[5]->property("Value"); cell[6] = work_sheet->querySubObject("Cells(int,int)",i,columns_start+6);
cell_value[6] = cell[6]->property("Value"); cell[7] = work_sheet->querySubObject("Cells(int,int)",i,columns_start+7);
cell_value[7] = cell[7]->property("Value"); cell[8] = work_sheet->querySubObject("Cells(int,int)",i,columns_start+8);
cell_value[8] = cell[8]->property("Value"); cell[9] = work_sheet->querySubObject("Cells(int,int)",i,columns_start+9);
cell_value[9] = cell[9]->property("Value"); cell[10] = work_sheet->querySubObject("Cells(int,int)",i,columns_start+10);
cell_value[10] = cell[10]->property("Value"); cell[11] = work_sheet->querySubObject("Cells(int,int)",i,columns_start+11);
cell_value[11] = cell[11]->property("Value"); cell[12] = work_sheet->querySubObject("Cells(int,int)",i,columns_start+12);
cell_value[12] = cell[12]->property("Value"); datasave->CRETM = gettimetss();
datasave->pro_name = cell_value[0].toString();
datasave->PSTM = cell_value[1].toString();
datasave->PETM = cell_value[2].toString();
datasave->Par_name = cell_value[3].toString();
datasave->PARSTM = cell_value[4].toString();
datasave->PARETM = cell_value[5].toString();
datasave->Sta_name = cell_value[6].toString();
datasave->STASTM = cell_value[7].toString();
datasave->STAETM = cell_value[8].toString();
datasave->INFOR = cell_value[9].toString();
datasave->DELTM = cell_value[10].toString();
datasave->REASION = cell_value[11].toString();
datasave->FINTM = cell_value[12].toString();
QString sql_insert = "insert into project values('";
sql_insert +=datasave->pro_name;
sql_insert +="','";
sql_insert +=datasave->PSTM;
sql_insert +="','";
sql_insert +=datasave->PETM;
sql_insert +="','";
sql_insert +=datasave->Par_name;
sql_insert +="','";
sql_insert +=datasave->PARSTM;
sql_insert +="','";
sql_insert +=datasave->PARETM;
sql_insert +="','";
sql_insert +=datasave->Sta_name;
sql_insert +="','";
sql_insert +=datasave->STASTM;
sql_insert +="','";
sql_insert +=datasave->STAETM;
sql_insert +="','";
sql_insert +=datasave->INFOR;
sql_insert +="','";
sql_insert +=datasave->FINTM;
sql_insert +="','";
sql_insert +=datasave->DELTM;
sql_insert +="','";
sql_insert +=datasave->REASION;
sql_insert +="','";
sql_insert +=datasave->CRETM;
sql_insert +="')";
QSqlQuery insert_data(*projectdb);
insert_data.exec(sql_insert);
// qDebug()<<sql_insert;
emit sys_data();
exceltip->setnumber(i);
delaymsec(10);
/****************************************************************************************************************/
}
}
}
exceltip->setfinish(true);
if(exceltip->exec() == QDialog::Accepted)
{
ui->pushButton_Cancle->setEnabled(true);
ui->pushButton_close->setEnabled(true);
ui->pushButton_save->setEnabled(true);
ui->pushButton_Excel->setEnabled(true);
ui->pushButton_update->setEnabled(true);
getname();
}
} /*******************************************************************************/ void AddDialog::on_pushButton_Excel_clicked() //打开一个Excel文件,完了要调用Excel解析函数
{
QString filename = QFileDialog::getOpenFileName(this);
if(!filename.isEmpty())
{
readExcel(filename);
}
}
//自定义延时函数 //无阻塞延时函数
void AddDialog::delaymsec(int msec)
{
QTime dieTime = QTime::currentTime().addMSecs(msec);
while (QTime::currentTime()<dieTime)
{
QCoreApplication::processEvents(QEventLoop::AllEvents,100);
}
}
Qt 解析EXcel文件的更多相关文章
- Java:JXL解析Excel文件
项目中,有需求要使用JXL解析Excel文件. 解析Excel文件 我们先要将文件转化为数据流inputStream. 当inputStream很大的时候 会造成Java虚拟器内存不够 抛出内存溢出 ...
- c++ 读取并解析excel文件方法
用Cocos开发模型特效工具编辑器,跨Mac和windows,当中有个需求是读取并解析excel文件,但网上的查找的例子几乎都只能是在windows下面使用,再或者是命令行脚本之类的.于是,自己写了一 ...
- 解析Excel文件并把数据存入数据库
前段时间做一个小项目,为了同时存储多条数据,其中有一个功能是解析Excel并把其中的数据存入对应数据库中.花了两天时间,不过一天多是因为用了"upload"关键字作为URL从而导致 ...
- Java通过jxl解析Excel文件入库,及日期格式处理方式 (附源代码)
JAVA可以利用jxl简单快速的读取文件的内容,但是由于版本限制,只能读取97-03 xls格式的Excel. 本文是项目中用到的一个实例,先通过上传xls文件(包含日期),再通过jxl进行读取上传 ...
- Jxl创建Excel文件和解析Excel文件
import java.io.File; import jxl.Workbook; import jxl.write.Label; import jxl.write.WritableSheet; im ...
- nodejs 解析excel文件
app.js: var FileUpload = require('express-fileupload') app.use(FileUpload()); service.js: npm instal ...
- vue下载和上传excle数据文件,解析excel文件数据并存在数据库中
下载: VUE: window.open("xxxx/downloadOldTaskDataFile.do_", "_blank"); JAVA: /** * ...
- 【Java】使用Apache POI生成和解析Excel文件
概述 Excel是我们平时工作中比较常用的用于存储二维表数据的,JAVA也可以直接对Excel进行操作,分别有jxl和poi,2种方式. HSSF is the POI Project's pure ...
- poi解析Excel文件版本问题
poi解析Excel文件时有两种格式: HSSFWorkbook格式用来解析Excel2003(xls)的文件 XSSFWorkbook格式用来解析Excel2007(xlsx)的文件 如果用HSSF ...
随机推荐
- POJ 3264 Balanced Lineup 【ST表 静态RMQ】
传送门:http://poj.org/problem?id=3264 Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total S ...
- java 中重载(Overload)和重写(Override)的区别
首先重载和重写是应用于两个不同场景下面的两种不同的手段: 两者各自的特征: 重载(Overload):首先是位于一个类之中或者其子类中,具有相同的方法名,但是方法的参数不同,返回值类型可以相同也可以不 ...
- VC MFC工具栏(CToolBar)控件(转)
工具栏 工具栏控件在控件面板里没有对应的选项(图标),但有一个工具栏控件类CToolBar,所以我们如果要创建一个工具栏控件并显示在窗口里的话,只能用代码来完成,事实上任何一种控件,都可以用代码创建, ...
- 撸一个简单的MVVM例子
我个人以为mvvm框架里面最重要的一点就是VM这部分,它要与Model层建立联系,将Model层转换成可以被View层识别的数据结构:其次也要同View建立联系,将数据及时更新到View层上,并且响应 ...
- 大数据框架-spark
相关详细说明:https://www.csdn.net/article/2015-07-10/2825184 RDD:弹性分布式数据集. Operation:Transformation 和Actio ...
- 管理Django1.9静态文件static
管理Django1.9静态文件static 网站通常需要增加图片.JavaScript.或者CSS等文件提供服务.在Django中,我们把这些文件称为“静态文件”(static files).Djan ...
- KMP初探
最近在做字符串匹配,沉迷于indexof无法自拔,但是考虑到大数据处理的时间复杂度,决定研究一波KMP. 在这我就不讲什么原理了,转自: https://www.cnblogs.com/zhangti ...
- #leetcode刷题之路14-最长公共前缀
编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". 示例 1: 输入: ["flower","flow" ...
- 远程连接Oracle 服务器 解决Oracle查询中文乱码
Dos方法: 依托于 目录下的文件 使用plsql developer 客户端软件进行连接 需要配置一下: 就是把Dos的客户端配置进来 然后,把服务器端的文件拷贝到你的的机器 并设置TNS_ADMI ...
- 浅谈vue,小程序,react基础绑定值
最近一直在用react开发项目,碰见的问题千千万,很多,但是都殊途同源,唯一区别大的就是没有像vue的双向绑定,也没有小程序的单向方便,比如: vue v-modal="msg" ...