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 ...
随机推荐
- property(四十)
一个静态属性property本质就是实现了get,set,delete三种方法 用法: class Foo: @property def AAA(self): print('get的时候运行我啊') ...
- 实现在某一指定位置的div在窗口滚动到指定位置的时候fixed定位
HTML: <div class="top"> ·····内容 </div> <div class="scroll">< ...
- 移动端自动化测试-Windows-Android-Appium环境搭建
1.安装JDK,并且配置好[JAVA_HOME]和[path]两个环境变量 1.1.JAVA_HOME:指向JDK的安装路径(如:C:\Program Files (x86)\Java\jdk1.7. ...
- teleport使用说明
teleport使用说明 浏览器下载网页:只能浏览主页和少数网页,其它不能浏览,容量几百kb teleport下载项目一能完全离线看网页,7328多文件 9个JPG文件,大小134M te ...
- 无法使用备份文件 'D:\20160512.bak',因为原先格式化该文件时所用扇区大小为 512,而目前所在设备的扇区大小为 4096
删除原先备份的记录 这里再加一条,如果你备份的文件还原有兼容性的问题,那就用低版本的sql做备份,这样的话哪里都能用
- 8、Python-函数
定义 def printInfo(): print("人生苦短,我用Python") 调用 def printInfo(): print("人生苦短,我用Python&q ...
- JAVA记录-String/StringBuilder/StringBuffer区别
- SPOJ 839 OPTM - Optimal Marks (最小割)(权值扩大,灵活应用除和取模)
http://www.spoj.com/problems/OPTM/ 题意: 给出一张图,点有点权,边有边权 定义一条边的权值为其连接两点的异或和 定义一张图的权值为所有边的权值之和 已知部分点的点权 ...
- DOM-Document对象
一. 整体介绍 这里介绍DOM对象中的Document对象. 何为Document对象?每个载入浏览器的HTML文档都会成为Document对象,Document对象可以帮助我们对所有的HTML ...
- JavaScript 无刷新修改浏览器URL地址栏
//发现地址栏已改为:newUrlvar stateObject = {}; var title = "Wow Title"; var newUrl = "/my/awe ...