Qt之如何写入Excel文件(一)

Qt之如何写入Excel文件(一)

    • 概述:
    • 代码:
      • .cpp
      • .h
    • 运行效果图:
    • over:
    • 文末一句话:

概述:

前面文章一直分享如何如何读取Excel文件,两种方式
链接: 使用Qt读取Excel.
链接: 使用qtxlsx开源库读取Excel.
今天分享下如何使用Qt写入Excel文件,此案例功能是从文件读取数据加载到界面表格,修改界面表格数据后再将界面表格数据保存到Excel文件。
大家可以关注公众号“Qt幻想家”获取工程源码;

代码:

.cpp

void CExcel::slot_Save()
{
	//!!!选择要保存的文件
	QString filePath = QFileDialog::getSaveFileName(this, "Save", "", "*.xlsx");

	//!!!判空处理
	if (filePath.isEmpty())
		return;

	QAxObject excel("Excel.Application");

	//!!!获取工作簿集合
	QAxObject*workbooks = excel.querySubObject("WorkBooks");
	//!!!新建工作簿
	workbooks->querySubObject("Add");
	//!!!获取当前工作簿
	QAxObject*workbook = excel.querySubObject("ActiveWorkBook");

	if (workbook == nullptr)
		return;

	//!!!获取表页对象
	QAxObject*worksheets = workbook->querySubObject("WorkSheets");
	//!!!获取第一页
	QAxObject*worksheet = worksheets->querySubObject("Item(int)", 1);
	//!!!获取权限
	QAxObject*usedrange = worksheet->querySubObject("Usedrange");

	//!!!遍历获取数据将数据写入文件
	for (int i = 0;i < ui.tableWidget->rowCount();i++)
	{
		for (int j = 0; j < ui.tableWidget->columnCount()-1; j++)
		{
			//if (i == 0)
			//{
				//worksheet->querySubObject("Cells(int, int)", i + 1, j + 1)->dynamicCall("setValue(const QVariant&)", ui.tableWidget->horizontalHeaderItem(j)->text().toStdString().c_str());
			//}
			//else
			//{
				//worksheet->querySubObject("Cells(int, int)", i + 1, j+1)->dynamicCall("SetNumberFormatLocal(const QVariant&)", "@");
				worksheet->querySubObject("Cells(int, int)", i + 1, j + 1)->dynamicCall("setValue(const QVariant&)", ui.tableWidget->item(i, j)->text().toStdString().c_str());

			//}
		}
		//excelDataInfo info;
		//info.num = ui.tableWidget->item(i, 0)->text().toInt();
		//info.x = ui.tableWidget->item(i, 1)->text().toFloat();
		//info.de = ui.tableWidget->item(i, 2)->text();
		//vecData.push_back(info);
	}
	//!!!保存文件
	workbook->dynamicCall("SaveAs(const QString&)", QDir::toNativeSeparators(filePath));
	workbooks->dynamicCall("Close()");
	excel.dynamicCall("Quit()");
}

.h

#pragma once
/*
*	@file		:CExcel.h
*	@author		:Fantast
*	@date		:2021-11-23 10:22
*	@version	:1.0v
*	@description:win下读取excel文件到界面表格中修改表格内容在保存到excel文件
*/
#include 
#include "ui_CExcel.h"


//!!!用来存储每列数据
typedef struct ExcelData
{
	int num;	//!!!孔号
	float x;	//!!!坐标x
	QString de;	//!!!描述
}excelDataInfo;



//!!!excel
#include 

//!!!打开文件窗口
#include 

class CExcel : public QWidget
{
	Q_OBJECT

public:
	CExcel(QWidget *parent = Q_NULLPTR);
	~CExcel();
private:
	//!!!初始化
	void Init();
	//!!!初始化信号槽
	void initConnect();
	//!!!读取文件数据存储
	void get_ExcelData(const QString &filePath);
	//!!!将读取数据加载到表格
	void set_DataTabWidget();

private slots:
	//!!!打开文件
	void slot_Open();
	//!!!保存文件
	void slot_Save();

private:
	Ui::CExcelClass ui;
	//QAxObject* excel;                            //操作Excel文件对象(open-save-close-quit)
	//QAxObject* workbooks;                        //总工作薄对象
	//QAxObject* workbook;                         //操作当前工作薄对象
	//QAxObject* worksheets;                       //文件中所有表页
	//QAxObject* worksheet;                        //存储第n个sheet对象
	//QAxObject* usedrange;                        //存储当前sheet的数据对象
	QVector<excelDataInfo> vecData;				 //存储文件中多行数据
};

运行效果图:

over:

欢迎大家关注作者在文末评论、点赞、转发以及批评指正!
如果大家有更好的方法或有问题可以在文末评论一起讨论!
共同学习!
共同进步!

文末一句话:

你能在浪费时间中获得乐趣,就不是浪费时间
——————————————————罗素

你可能感兴趣的:(Excel,qt,c++,qlxsx)