使用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;
}
以上代码有借鉴网上的一部分,如有侵权请私信我。如有错误请指正。