項目中需要對Excel進行操作,把數據中的數據寫入到Excel文件中。在數據量大的情況下,操作Excel是一件費時的操作。 但是執行到下列代碼時就會出現空指針的情況: 第四行返回的workbooks指針是一個空指針,無法進行向下的Excel操作。這是因為QAxObject對象是預設在單線程下使用, ...
項目中需要對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");
這樣就可以解決上面的空指針問題。