项目中需要对Excel进行操作,把数据中的数据写入到Excel文件中。在数据量大的情况下,操作Excel是一件费时的操作。
但是执行到下列代码时就会出现空指针的情况:
1 QAxObject *excel = new QAxObject("Excel.Application"); 2 excel->setProperty("Visible", false); 3 4 QAxObject *workbooks = excel->querySubObject("WorkBooks");
第四行返回的workbooks指针是一个空指针,无法进行向下的Excel操作。这是因为QAxObject对象是默认在单线程下使用,
解决这个问题需要一个初始化函数,指定在多线程下可以使用QAxObject 指针。
1 #include <ObjBase.h> 2 3 CoInitializeEx(NULL, COINIT_MULTITHREADED); 4 QAxObject *excel = new QAxObject("Excel.Application"); 5 excel->setProperty("Visible", false); 6 7 QAxObject *workbooks = excel->querySubObject("WorkBooks");
这样就可以解决上面的空指针问题。