Qt-excel文件操做方法

版權聲明:若無來源註明, Techie亮博客文章均爲原創。 轉載請以連接形式標明本文標題和地址:
本文標題:Qt-excel文件操做方法     本文地址: http://techieliang.com/2017/11/464/

1. Qt-QAxObject

QAxObject是Qt提供的包裝COM組件的類,經過COM操做Excel須要使用QAxObject類,使用此類還須要在pro文件增長「QT += axcontainer」html

QAxObject的具體說明請見幫助文檔app

2. 與excel com鏈接的方法

  1. #include <QAxObject> //注意包含此頭文件,同時在pro增長QT+= axcontainer
  2. QAxObject *excel = new QAxObject(this);//創建excel操做對象
  3. excel->setControl("Excel.Application");//鏈接Excel控件
  4. excel->dynamicCall("SetVisible (bool Visible)","false");//設置爲不顯示窗體
  5. excel->setProperty("DisplayAlerts", false);//不顯示任何警告信息,如關閉時的是否保存提示
  6. excel->dynamicCall(?"Quit(void)"?);//關閉excel程序,操做完成後記着關閉,因爲是隱藏的看不到,不關閉進程會有不少excel.exe
  7. //關閉excel程序以前記着先關閉.xls文件,具體見後續內容:workbook->dynamicCall("Close(Boolean)", false); //關閉文件

3. Excel基本操做

下面只介紹主要讀寫操做的方法,若須要修改單元格格式等操做,請看「Excel VBA參考手冊.chm」或者其餘相似資料大數據

手冊分享地址: 連接: https://pan.baidu.com/s/1pLvC5nl 密碼: dnikui

3.1. excel文件操做

獲取當前工做簿的集合this

  1. QAxObject *workbooks = excel->querySubObject("WorkBooks");//獲取工做簿(excel文件)集合

新建一個工做簿spa

  1. workbooks->dynamicCall("Add");//新建一個工做簿
  2. QAxObject *workbook = excel->querySubObject("ActiveWorkBook");//獲取當前工做簿

打開一個已有的工做簿excel

  1. QString excel_file_path = "XXXX.xlsx";
  2. QAxObject* workbook = workbooks->querySubObject("Open(const QString&)", excel_file_path);

保存工做簿htm

  1. workbook->dynamicCall("Save()"); //保存文件
  2. workbook->dynamicCall("Close(Boolean)", false); //關閉文件
  3. excel->dynamicCall(?"Quit(void)"?);//關閉excel

另存爲工做簿對象

  1. //用QDir::toNativeSeparators, 將路徑中的"/"轉換爲"\",不然沒法保存,/只是qt中能夠識別
  2. workbook->dynamicCall("SaveAs(const QString&)", QDir::toNativeSeparators(excel_file_path));
  3. workbook->dynamicCall("Close (Boolean)", false); //關閉文件
  4. excel->dynamicCall(?"Quit(void)"?);//關閉excel

3.2. sheet工做表操做

下面的代碼用到的workbook都是上面工做簿操做後獲得的,也就是對某一個工做簿(excel文件)進行操做排序

獲取全部工做表

  1. QAxObject *worksheets = workbook->querySubObject("Sheets");

根據序號獲取某個工做表,序號順序就是excel打開後下方的排序

  1. QAxObject *worksheet = worksheets->querySubObject("Item(int)",1);

獲取表中的行數列數

  1. QAxObject* usedrange = worksheet->querySubObject("UsedRange");//sheet範圍
  2. int intRowStart = usedrange->property("Row").toInt();//起始行數
  3. int intColStart = usedrange->property("Column").toInt(); //起始列數
  4. QAxObject *rows, *columns;
  5. rows = usedrange->querySubObject("Rows");//行
  6. columns = usedrange->querySubObject("Columns");//列
  7. int intRow = rows->property("Count").toInt();//行數
  8. int intCol = columns->property("Count").toInt();//列數

3.3. 內容操做

數據內容操做-獲取單元格-基於座標

  1. QAxObject* cell = worksheet->querySubObject("Cells(int, int)", i, j);

數據內容操做-獲取單元格-基於行列名稱

  1. QAxObject* cell = worksheet->querySubObject("Range(QVariant, QVariant)", "A1");

數據內容操做-讀單元格內容

  1. QVariant cell_value = cell->property("Value");

數據內容操做-寫單元格內容

  1. cell->setProperty("Value", "內容");

4. 其餘

4.1. 大數據量讀取

讀取全部單元格內容-數據量大請使用此方式,只須要進行一次操做便可讀取全部內容到內容,避免重複每一個單元格進行QAxObject操做

  1. QVariant var;
  2. QAxObject *usedRange = sheet->querySubObject("UsedRange");//獲取用戶區域範圍
  3. if(NULL == usedRange || usedRange->isNull()) {
  4. return var;
  5. }
  6. var = usedRange->dynamicCall("Value");//讀取區域內全部值
  7. delete usedRange;

此時結果以QVariant保存,須要自行轉換成QList<QList<QVariant>>

  1. QList<QList<QVariant>> excel_list;
  2. auto rows = var.toList();
  3. for(auto row:rows) {
  4. excel_list.append(row.toList());
  5. }

4.2. 大數據量寫入

大數據以QList<QList<QVariant>>存儲,與讀取相似,此處須要先指定區域範圍

  1. QAxObject *user_range = this->sheet->querySubObject("Range(const QString&)","A1:D100");//範圍

而後寫入數據

  1. range->setProperty("Value", var);//須要將QList<QList<QVarient>>轉換爲QVarient

4.3. 範例:一個完整的打開-讀取-關閉的操做

  1. QString excel_file_path = QDir::currentPath()+"/a.xlsx";
  2. excel_file_path = QDir::toNativeSeparators(excel_file_path);
  3. QAxObject *excel = new QAxObject(this);//創建excel操做對象
  4. excel->setControl("Excel.Application");//鏈接Excel控件
  5. excel->setProperty("Visible", true);//顯示窗體看效果
  6. excel->setProperty("DisplayAlerts", true);//顯示警告看效果
  7. QAxObject *workbooks = excel->querySubObject
  8. ("WorkBooks");//獲取工做簿(excel文件)集合
  9. workbooks->dynamicCall("Open(const QString&)", excel_file_path);
  10. QAxObject *workbook = excel->querySubObject("ActiveWorkBook");
  11. QAxObject *worksheet = workbook->querySubObject("WorkSheets(int)",1);
  12. QAxObject *usedRange = worksheet->querySubObject("UsedRange");
  13. QVariant var = usedRange->dynamicCall("Value");//這裏是全部的內容
  14. workbook->dynamicCall( "Close(Boolean)", false );
  15. excel->dynamicCall( "Quit(void)" );
  16. delete excel;

注意: 一、此範例爲了看到效果吧窗口和警告設置爲了顯示,請自行改成false 二、excel全部操做均是經過QAxObject 進行COM組件的操做,包括打開文件也是,因此路徑必須傳遞完整路徑,不能傳遞相對路徑 三、QAxObject自身會維護new出的空間,直接delete第一個QAxObject 便可 四、全部內容保存在var的變量中 五、上述操做均爲判斷返回值,若文件不存在後續內容會報錯

相關文章
相關標籤/搜索