c++ qt 操作Excel 实现冻结窗格的功能。

使用qt操作Excel的一些基本操作内容我就不介绍了,你们搜一下就可以了,如果不想麻烦可以去下面这个链接地址看一下。
qt操作Excel基础使用技巧
本文主要讲一个知识点,就是使用qt操作Excel实现冻结窗格的功能。因为我搜了好久没找到实现冻结窗格的功能的例子。就搜到一个c#写的,不多说上代码。

	QAxObject* m_pApplication = new QAxObject(this);
	if (m_pApplication->setControl("Excel.Application"))
	{
		qDebug() << "Excel.Application连接成功!" << endl;
	}
	else
	{
		m_pApplication->setControl("ket.Application");//连接wps的Excel
	}
	m_pApplication->dynamicCall("SetVisible(bool Visible)", "false");//不显示窗体
	m_pApplication->setProperty("DisplayAlerts", false);//不显示任何警告
	QAxObject* m_pWorkBooks = m_pApplication->querySubObject("WorkBooks");//获取工作薄集合
	if (m_pWorkBooks!=NULL)
	{
		QFile file("D:/test.xlsx");
		if (file.exists())
		{
			bool rfl = QFile::remove("D:/test.xlsx");//如果存在同名文件则删除源文件
			m_pWorkBooks->dynamicCall("Add");
			//m_pWorkBooks->querySubObject("Open(const QString &)", filname);//打开文件
		}
		else
		{
			m_pWorkBooks->dynamicCall("Add");
		}
		QAxObject* m_pWorkBook = m_pApplication->querySubObject("ActiveWorkBook");
		if (m_pWorkBook!=NULL)
		{
			QAxObject* m_pSheets = m_pWorkBook->querySubObject("Sheets");
			if (m_pSheets!=NULL)
			{
				QAxObject* m_pSheet = m_pSheets->querySubObject("Item(int)", 1);//获取工作表集合中的工作表1
			}
		}
		//最重要的部分(实现冻结窗格)
		if (m_pApplication != NULL)
		{
			QAxObject *aboj = m_pApplication->querySubObject("ActiveWindow");
			if (aboj!=NULL)
			{
				bool blFree= aboj->setProperty("FreezePanes",false);//首先先把冻结窗格去掉,防止Excel已经设置的冻结窗格导致后面设置的不成功。
				bool blSpliC = aboj->setProperty("SplitColumn", 0);//,第几列,目前设置的是Excel的第0列
				bool blSpliR = aboj->setProperty("SplitRow", 1);//第几行,目前设置的是第1行
				blFree = aboj->setProperty("FreezePanes", true);//设置冻结窗格属性为true
			}
		}
	}
	else
	{
		qDebug() << "获取工作薄集合失败!" << endl;
	}

以上代码有借鉴网上的一部分,如有侵权请私信我。如有错误请指正。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值