Qt ------ excel 操作
写 excel
// step1:连接控件
QAxObject* excel = new QAxObject(this);
excel->setControl("Excel.Application"); // 连接Excel控件
excel->dynamicCall("SetVisible (bool Visible)", "false"); // 不显示窗体
excel->setProperty("DisplayAlerts", false); // 不显示任何警告信息。如果为true, 那么关闭时会出现类似"文件已修改,是否保存"的提示 // step2: 打开工作簿
QAxObject* workbooks = excel->querySubObject("WorkBooks"); // 获取工作簿集合
workbooks->dynamicCall("Add"); // 新建一个工作簿
QAxObject* workbook = excel->querySubObject("ActiveWorkBook"); // 获取当前工作簿 // step3: 打开sheet
QAxObject* worksheet = workbook->querySubObject("WorkSheets(int)", ); // 获取工作表集合的工作表1, 即sheet1 QAxObject* cell = worksheet->querySubObject("Cells(int, int)", , ); cell->dynamicCall("SetValue(conts QVariant&)", QVariant()); workbook->dynamicCall("SaveAs(const QString&)",QDir::currentPath() + "/IMEI.xlsx");
workbook->dynamicCall("Save()"); //保存文件
workbook->dynamicCall("Close(Boolean)", false); //关闭文件 delete excel;
读 excel
QAxObject excel("Excel.Application");
excel.setProperty("Visible", false); //隐藏打开的excel文件界面
QAxObject *workbooks = excel.querySubObject("WorkBooks");
QAxObject *workbook = workbooks->querySubObject("Open(QString, QVariant)", QDir::currentPath() + "/IMEI.xls"); //打开文件
QAxObject * worksheet = workbook->querySubObject("WorkSheets(int)", ); //访问第一个工作表
QAxObject * usedrange = worksheet->querySubObject("UsedRange");
QAxObject * rows = usedrange->querySubObject("Rows");
int intRows = rows->property("Count").toInt(); //行数
qDebug() << "使用了 " << intRows << " 行"; QString Range = "A1:B" +QString::number(intRows);
QAxObject *allEnvData = worksheet->querySubObject("Range(QString)", Range); //读取范围
QVariant allEnvDataQVariant = allEnvData->property("Value");
QVariantList allEnvDataList = allEnvDataQVariant.toList(); for(int i=; i< intRows; i++)
{
QVariantList allEnvDataList_i = allEnvDataList[i].toList() ;
QString data1 = allEnvDataList_i[].toString(); //第i行第0列的数据
qDebug() << data1;
}
workbooks->dynamicCall("Close()");
excel.dynamicCall("Quit()");
如果出现以下情况,可能是所选的Excel控件不支持要打开的excel文件(.xls、.xlsx)
读写 excel
QAxObject *excel = new QAxObject("Excel.Application");
uint8_t flag = ;
excel->setProperty("Visible", false); //隐藏打开的excel文件界面
QAxObject *workbooks = excel->querySubObject("WorkBooks"); QFile file_xls(QDir::currentPath() + "/IMEI.xls");
QAxObject *workbook;
if(file_xls.exists())
{
qDebug() << "文件已存在";
workbook = workbooks->querySubObject("Open(QString, QVariant)", QDir::currentPath() + "/IMEI.xls"); //打开文件
}else
{
qDebug() << "文件不存在,创建一个";
workbooks->dynamicCall("Add"); // 新建一个工作簿
workbook = excel->querySubObject("ActiveWorkBook"); // 获取当前工作簿
} QAxObject * worksheet = workbook->querySubObject("WorkSheets(int)", ); //访问第一个工作表
QAxObject * usedrange = worksheet->querySubObject("UsedRange");
QAxObject * columns = usedrange->querySubObject("Columns");
columns->dynamicCall("AutoFit");
QAxObject * rows = usedrange->querySubObject("Rows");
int intRows = rows->property("Count").toInt(); //行数,实际使用0行或者1行,这个值都是1
QString Range = "A1:B" +QString::number(intRows);
QAxObject *allEnvData = worksheet->querySubObject("Range(QString)", Range); //读取范围
QVariant allEnvDataQVariant = allEnvData->property("Value");
QVariantList allEnvDataList = allEnvDataQVariant.toList(); QString data;
for(int i=; i< intRows; i++)
{
QVariantList allEnvDataList_i = allEnvDataList[i].toList() ;
data = allEnvDataList_i[].toString(); //第i行第1列的数据
if(data == IMEI_str)
{
flag = ;
qDebug() << "excel 内已含此 IMEI";
break;
}
qDebug() << data;
}
if((data == "") && (intRows == ))
{
intRows = intRows -;
}
qDebug() << "使用了 " << intRows << " 行";
if(flag == )
{
QAxObject* cell = worksheet->querySubObject("Cells(int, int)", intRows+, );
cell->setProperty("NumberFormatLocal", "@"); // 设置为文本
cell->dynamicCall("SetValue(conts QVariant&)", QVariant(IMEI_str));
} if(!file_xls.exists())
{
workbook->dynamicCall("SaveAs(const QString&)",QDir::currentPath() + "/IMEI.xls");
}
workbook->dynamicCall("Close(Boolean)", true); //true为关闭前保存
excel->dynamicCall("Quit()");
delete excel;
Qt ------ excel 操作的更多相关文章
- Qt QAxObject操作excel文件过程总结(转):
正好同事问道Qt下操作excel. 转自:http://blog.csdn.net/a156392343/article/details/48092515 配制方面: 1.确保Excel软件在本地服务 ...
- Qt之操作Excel
Visual Basic for Applications(VBA)是一种Visual Basic的一种宏语言,主要能用来扩展Windows的应用程式功能,特别是Microsoft Office软件. ...
- Qt之excel 操作使用说明
学习背景: 适合熟悉些qt开发,但是不是深入了解的开发者学习.具体实现(qt 5.1版本),office2007 Excel做验证,Win 7(64位),如有讲解有误,欢迎斧正! 一.简单介绍 QAx ...
- Npoi导入导出Excel操作
之前公司的一个物流商系统需要实现对订单的批量导入和导出,翻阅了一些资料,最后考虑使用NPOI实现这个需求. 在winform上面实现excel操作:http://www.cnblogs.com/Cal ...
- Delphi Excel 操作大全
Delphi Excel 操作大全 (一) 使用动态创建的方法首先创建 Excel 对象,使用ComObj:var ExcelApp: Variant;ExcelApp := CreateOleObj ...
- C#EXCEL 操作类--C#ExcelHelper操作类
主要功能如下1.导出Excel文件,自动返回可下载的文件流 2.导出Excel文件,转换为可读模式3.导出Excel文件,并自定义文件名4.将数据导出至Excel文件5.将指定的集合数据导出至Exce ...
- Excel 操作类
转载:http://www.cnblogs.com/fellowcheng/archive/2010/08/21/1805158.html ExcelHelper(Excel2007) Code hi ...
- C# excel操作
开源的Excel操作项目: http://www.cnblogs.com/lwme/archive/2011/11/27/2265323.html 添加引用:Microsoft Excel 11.0 ...
- [Excel操作]Microsoft Office Excel 不能访问文件
最近,客户服务器迁移,因操作系统环境变化而引起的的环境问题一堆,遇到的问题并解决方法在“[Excel]操作”类别会体现. Microsoft Office Excel 不能访问文件“C:\\LMSEx ...
随机推荐
- Python学习之路——Day02
今日内容: 1.编程语言介绍(***) 2.python介绍(***) 3.安装cpython解释器(多个版本)(****) 4.运行python程序的两种方式(****) 4.1 交互式 4.2 命 ...
- react 入坑笔记(四) - React 事件绑定和传参
React 事件处理 建议:在了解 js 的 this 取值后食用更佳. 一.react 与 Html 中用法的异同和注意点 html 中的绑定事件的写法: <button onclick=&q ...
- 4.namespace
命名空间( namespace)是 Linux 内核的一个强大特性,为容器虚拟化的实现带来极大便 利. 利用这一特性,每个容器都可以拥有自己单独的命名空间,运行在其中的应用都像是在 独立的操作系统环境 ...
- cuda编程-并行规约
利用shared memory计算,并避免bank conflict:通过每个block内部规约,然后再把所有block的计算结果在CPU端累加 代码: #include <cuda_runti ...
- 从身份证号码中获取性别、出生日期、籍贯,并更新mongodb
有这样的需求,人员信息是存在mongodb中,需要存放人员的身份证.性别.出生日期.籍贯等信息.通过脚本导入这些信息,但是只导入了身份证号码,其他信息空缺.现在需要补全其他信息. 其实身份证信息就包含 ...
- js 异步代码
这段时间一直在用node.js做毕设的后台,所以需要一些异步代码操作,主要的异步方式有:Promise.Generator 和 async / await,但下面主要讲 Promise 和 async ...
- 进程PID 与PPID
# 同一个程序执行多次是多个进程 import time import os print('爹是:',os.getppid()) #查看父进程 print('me是: ',os.getpid()) # ...
- 使用Putty执行Rsync命令
背景介绍:公司的文件服务器有多个,一个Master服务器,10个左右的Slave服务器. 当Master服务器中的文件更新之后,Slave服务器中的文件也必须做相对应的同步操作. 公司目前使用的Rsy ...
- [luogu2503][HAOI2006]均分数据【模拟退火】
题目描述 已知N个正整数:A1.A2.--.An .今要将它们分成M组,使得各组数据的数值和最平均,即各组的均方差最小.均方差公式如下: 分析 模拟退火学习笔记:https://www.cnblogs ...
- rt-thread 低优先级线程挂起高优先级线程失败
@2019-01-13 [小记] 使用rt-thread线程管理功能时,低优先级线程挂起高优先级线程失败,高优先级线程或同等优先级线程挂起低优先级线程则成功.