Qt Excel
在pro文件添加
QT +=axcontainer
头文件
#include <QAxObject>
void MainWindow::on_btnSelectFileDialog_clicked()
{
QString fileName=QFileDialog::getOpenFileName(this,"select Excel",excelDir,tr("Excel Files (*.xlsx *.xls)"));
if(fileName.lastIndexOf("/")>)
{
excelDir=fileName.mid(,fileName.lastIndexOf("/")+);
excelNewName=fileName.mid(fileName.lastIndexOf("/")+);
excelNewName=excelNewName.mid(,excelNewName.lastIndexOf("."))+"_new"+excelNewName.mid(excelNewName.lastIndexOf(".")); }
ui->leSourceExcel->setText(fileName); } QList<QString> tempData;
void MainWindow::on_btnGenerate_clicked()
{ //读取excel
QAxObject *myExcel=new QAxObject("Excel.Application");
if(!myExcel){ QMessageBox::critical(this, "错误信息", "EXCEL对象丢失");
return; }
myExcel->dynamicCall("SetVisible(bool)",false);
QAxObject *workBooks=myExcel->querySubObject("WorkBooks");
QAxObject *workBook=workBooks->querySubObject("Open(QString,QVariant",ui->leSourceExcel->text());
QAxObject * workSheet = workBook->querySubObject("WorkSheets(int)", );//打开第一个sheet //QAxObject * worksheet = workbook->querySubObject("WorkSheets");//获取sheets的集合指针
//int intCount = worksheet->property("Count").toInt();//获取sheets的数量 QAxObject * usedRange = workSheet->querySubObject("UsedRange");//获取该sheet的使用范围对象
QAxObject * rows = usedRange->querySubObject("Rows");
QAxObject * columns = usedRange->querySubObject("Columns"); //获取行数和列数
int intRowStart = usedRange->property("Row").toInt();
int intColStart = usedRange->property("Column").toInt();
int intCols = columns->property("Count").toInt();
int intRows = rows->property("Count").toInt(); //获取excel内容
QString rowData;
tempData.clear();
for (int i = intRowStart; i < intRowStart + intRows; i++) //行
{
rowData="";
for (int j = intColStart; j < intColStart + intCols; j++) //列
{
QAxObject * cell = workSheet->querySubObject("Cells(int,int)", i, j ); //获取单元格 qDebug() << i << j <<cell->dynamicCall("Value2()").toString(); //正确
rowData+=cell->dynamicCall("Value2()").toString()+",";
}
tempData.append(rowData); }
workBook->dynamicCall("Close (Boolean)", false);
myExcel->dynamicCall("Quit(void)");
delete myExcel;//一定要记得删除,要不线程中会一直打开excel.exe
myExcel=NULL; } void MainWindow::saveExcel()
{ QAxObject *myExcel=new QAxObject("Excel.Application");
if(!myExcel){ QMessageBox::critical(this, "错误信息", "EXCEL对象丢失");
return; }
myExcel->dynamicCall("SetVisible(bool)",false);//不显示窗体
myExcel->setProperty("DisplayAlerts", false);//不显示任何警告信息。如果为true那么在关闭是会出现类似“文件已修改,是否保存”的提示
QAxObject *workBooks=myExcel->querySubObject("WorkBooks");
workBooks->dynamicCall("Add");//新建一个工作簿
QAxObject *workBook = myExcel->querySubObject("ActiveWorkBook");//获取当前工作簿
QAxObject *workSheets = workBook->querySubObject("Sheets");//获取工作表集合
QAxObject *workSheet = workSheets->querySubObject("Item(int)",);//获取工作表集合的工作表1,即sheet1 for(int i=;i<tempData.count();i++){ QStringList rowData=tempData[i].split(",");\
QAxObject *cellA=workSheet->querySubObject("Range(QVariant, QVariant)","A"+QString::number(i+));
cellA->dynamicCall("SetValue(const QVariant&)",QVariant(rowData[])); QAxObject *cellB=workSheet->querySubObject("Range(QVariant, QVariant)","B"+QString::number(i+));
cellB->dynamicCall("SetValue(const QVariant&)",QVariant(rowData[])); }
QString filePath=excelDir+excelNewName;
qDebug()<<filePath;
//保存至filepath,注意一定要用QDir::toNativeSeparators将路径中的"/"转换为"\",不然一定保存不了。
workBook->dynamicCall("SaveAs(const QString&)",QDir::toNativeSeparators(filePath)); workBook->dynamicCall("Close (Boolean)", false);
myExcel->dynamicCall("Quit(void)");
delete myExcel;
myExcel=NULL;
tempData.clear(); } void MainWindow::on_pushButton_clicked()
{
saveExcel();
}
Qt Excel的更多相关文章
- Qt ------ excel 操作
写 excel // step1:连接控件 QAxObject* excel = new QAxObject(this); excel->setControl("Excel.Appli ...
- Qt之操作Excel
Visual Basic for Applications(VBA)是一种Visual Basic的一种宏语言,主要能用来扩展Windows的应用程式功能,特别是Microsoft Office软件. ...
- 38.QT-QAxObject快速写入EXCEL示例
参考链接:https://blog.csdn.net/czyt1988/article/details/52121360 http://blog.sina.com.cn/s/blog_a6fb6cc9 ...
- QT操作EXCEL
介绍一下最基本的QT对EXCEL的读写操作. 声明:转载于:http://blog.csdn.net/czyt1988/article/details/52121360 在使用QT的操作数据库的时候, ...
- Qt QAxObject操作excel文件过程总结(转):
正好同事问道Qt下操作excel. 转自:http://blog.csdn.net/a156392343/article/details/48092515 配制方面: 1.确保Excel软件在本地服务 ...
- Qt 操作Excel
Qt对Excel的数据读/写操作没有现存的类,需要使用QAxObject,下面是从网上下载下来的一个封装好的类,感觉还可以,一般情况下够用,拿来给大家分享. 头文件: #ifndef EXCELENG ...
- Qt将表格table保存为excel(odbc方式)
首先是保存excel的方法,可参照: http://dzmlmszp.blog.163.com/blog/static/179271962014819111812531/ ok,进入正题. 现在我有一 ...
- 在Qt中用QAxObject来操作Excel
目录(?)[+] 下一篇:用dumpcpp工具生成的excel.h/excel.cpp来操纵Excel 最近写程序中需要将数据输出保存到Excel文件中.翻看<C++ GUI Pro ...
- qt 操作excel表格
自己编写的一个Qt C++类,用于操作excel表格,在Qt中操作excel需在.pro中增加CONFIG+=qaxcontainer配置. 1.打开Excel:objExcel = new QAx ...
随机推荐
- MVC中权限的知识点及具体实现代码
一:知识点部分 权限是做网页经常要涉及到的一个知识点,在使用MVC做权限设计时需要先了解以下知识: MVC中Url的执行是按照Controller->Action->View页面,但是我们 ...
- 百度地图infoWindow圆角处理
最近的一个项目用到了百度地图API里边的infoWindow弹框,但是百度自带的infoWindow弹框是个直角的矩形框,显示过于难看,于是有了将该框改为圆角的想法,但是API本身不支持样式的设置,所 ...
- spring对事务的配置
接下来我将给大家介绍spring事务配置的两种方式: 1.基于XML的事务配置.2.基于注解方式的事务配置. 前言:在我们详细介绍spring的两种声明式事务管理之前,我们需要先理解这些概念 1)sp ...
- Java逐行写入字符串到文件
下边是写东西到一个文件中的Java代码.运行后每一次,一个新的文件被创建,并且之前一个也将会被新的文件替代.这和给文件追加内容是不同的. 1. public static void writeFile ...
- 发送邮件时Unable to relay错误的解决方法 转
使用python的smtplib发送邮件,使用新浪的smtp服务,在本地测试正常.但把程序部署到服务器后,却连不上新浪的smtp服务器,可以ping通,但telnet 25端口失败,导致程序无法正常运 ...
- 常用nginx rewrite重定向-跳转实例:
1,将www.myweb.com/connect 跳转到connect.myweb.com rewrite ^/connect$ http://connect.myweb.com permanent; ...
- Java基础-Eclipse第三方安装包管理工具之Maven
Java基础-Eclipse第三方安装包管理工具之Maven 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 玩过Linux的小伙伴应该都知道yum吧,我们只要把搭建好的yum仓库配 ...
- Openresty+redis实现灰度发布
一.架构 环境: 192.168.189.131:tomcat服务 192.168.189.132:tomcat服务 192.168.189.130:OpenResty服务.redis服务 流程: 请 ...
- SQL Server 日期和时间类型
在Microsoft SQL Server的类型系统中,使用 date 表示日期类型,使用time表示时间类型,使用DateTime和DateTime2表示日期和时间的组合,DateTime2是Dat ...
- 6、JDBC-处理CLOB与BLOB
Blob 是一个二进制大型对象(文件),在MySQL中有四种 Blob 类型,区别是容量不同 TinyBlob 255B Blob 65KB MediumBlob 16MB LongBlob 4GB ...