欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Qt實現(xiàn)數(shù)據(jù)導(dǎo)出到xls的示例代碼

 更新時間:2022年01月12日 15:03:17   作者:feiyangqingyun  
導(dǎo)入導(dǎo)出數(shù)據(jù)到csv由于語法簡單,適用場景有限,于是本文將為大家介紹Qt如何實現(xiàn)導(dǎo)出數(shù)據(jù)到xls,感興趣的小伙伴可以跟隨小編一起試一試

一、前言

導(dǎo)入導(dǎo)出數(shù)據(jù)到csv由于語法簡單,適用場景有限,于是乎還是必須再造一個輪子導(dǎo)出數(shù)據(jù)到xls,在經(jīng)歷過數(shù)十年的項目實戰(zhàn)經(jīng)驗中不斷調(diào)整和優(yōu)化。尤其記得當(dāng)初第一個版本v0.01大概在2011年左右完成的,當(dāng)時是公司項目運行在嵌入式板子上,需要導(dǎo)出警情記錄,拷貝到電腦上打印,由于嵌入式根本沒有也不可能去安裝excel等軟件,硬著頭皮去研究了xml格式的xls文件,按照那個規(guī)則組合成簡單的導(dǎo)出數(shù)據(jù),這個思路想法理論上比QtXlsx要早,我也是后面大概在2015年后才發(fā)現(xiàn)有QtXlsx這個開源的輪子,而且思路不謀而合,都是采用xml格式的數(shù)據(jù)。QtXlsx主打各種格式數(shù)據(jù)單元格做成一個完成的通用的組件等,而我這個輪子更傾向于具體應(yīng)用場景,直接面對傻瓜用戶,傳入表名、字段集合幾個簡單的信息(現(xiàn)在直接放到了結(jié)構(gòu)體數(shù)據(jù)),就能直接刷刷的導(dǎo)出數(shù)據(jù),甚至簡單到現(xiàn)在支持直接傳入QTableWidget、QTableView控件就行,不要太簡單爽歪歪。

結(jié)構(gòu)體支持的參數(shù):

  • 文件名稱
  • 表名
  • 主標題
  • 副標題
  • 子標題1
  • 子標題2
  • 字段名稱集合
  • 字段寬度集合
  • 內(nèi)容集合
  • 行內(nèi)容分隔符
  • 子內(nèi)容分隔符
  • 邊框?qū)挾?/li>
  • 自動填數(shù)據(jù)類型 默認開啟
  • 數(shù)據(jù)單元格樣式 默認不開啟 不開啟可以節(jié)約大概30%的文件體積
  • 隨機顏色
  • 隨機顏色列索引集合
  • 校驗列
  • 校驗類型
  • 校驗值
  • 檢驗顏色

二、功能特點

組件同時集成了導(dǎo)出數(shù)據(jù)到csv、xls、pdf和打印數(shù)據(jù)。

所有操作全部提供靜態(tài)方法無需new,數(shù)據(jù)和屬性等各種參數(shù)設(shè)置采用結(jié)構(gòu)體數(shù)據(jù),極為方便。

同時支持QTableView、QTableWidget、QStandardItemModel、QSqlTableModel等數(shù)據(jù)源。

提供靜態(tài)方法直接傳入QTableView、QTableWidget控件,自動識別列名、列寬和數(shù)據(jù)內(nèi)容。

每組功能都提供單獨的完整的示例,注釋詳細,非常適合各階段Qter程序員。

原創(chuàng)導(dǎo)出數(shù)據(jù)機制,不依賴任何office組件或者操作系統(tǒng)等第三方庫,支持嵌入式linux。

速度超快,9個字段10萬行數(shù)據(jù)只需要2秒鐘完成。

只需要四個步驟即可開始急速導(dǎo)出海量數(shù)據(jù)比如100W條記錄到Excel。

同時提供直接寫入數(shù)據(jù)接口和多線程寫入數(shù)據(jù)接口,不卡主界面。

可設(shè)置標題、副標題、表名。

可設(shè)置導(dǎo)出數(shù)據(jù)的字段名、列名、列寬。

可設(shè)置末尾列自動拉伸填充,默認拉伸更美觀。

可設(shè)置是否啟用校驗過濾數(shù)據(jù),啟用后符合規(guī)則的數(shù)據(jù)特殊顏色顯示。

可指定校驗的列、校驗規(guī)則、校驗值、校驗值數(shù)據(jù)類型。

校驗規(guī)則支持 精確等于==、大于>、大于等于>=、小于<、小于等于<=、不等于!=、包含contains。

校驗值數(shù)據(jù)類型支持 整型int、浮點型float、雙精度型double,默認文本字符串類型。

可設(shè)置隨機背景顏色及需要隨機背景色的列集合。

支持分組輸出數(shù)據(jù),比如按照設(shè)備分組輸出數(shù)據(jù),方便查看。

可設(shè)置csv分隔符、行內(nèi)容分隔符、子內(nèi)容分隔符。

可設(shè)置邊框?qū)挾取⒆詣犹顢?shù)據(jù)類型,默認自動數(shù)據(jù)類型開啟。

可設(shè)置是否開啟數(shù)據(jù)單元格樣式,默認不開啟,不開啟可以節(jié)約大概30%的文件體積。

可設(shè)置橫向排版、紙張邊距等,比如導(dǎo)出到pdf以及打印數(shù)據(jù)。

支持圖文混排導(dǎo)出數(shù)據(jù)到pdf以及打印數(shù)據(jù),自動分頁。

靈活性超高,可自由更改源碼設(shè)置對齊方式、文字顏色、背景顏色等。

支持任意excel表格軟件,包括但不限于excel2003-2021、wps、openoffice等。

純Qt編寫,支持任意Qt版本+任意編譯器+任意系統(tǒng)。

三、體驗地址

體驗地址:https://pan.baidu.com/s/1ZxG-oyUKe286LPMPxOrO2A 提取碼:o05q 文件名:bin_dataout.zip

國內(nèi)站點:https://gitee.com/feiyangqingyun

國際站點:https://github.com/feiyangqingyun

四、效果圖

五、相關(guān)代碼

QStringList frmDataOut2::getContent()
{
    QStringList content;
    QString sql = QString("select * from MsgInfo limit %1").arg(100);
    QSqlQuery query;
    if (!query.exec(sql)) {
        return content;
    }

    //循環(huán)遍歷數(shù)據(jù)
    while (query.next()) {
        QStringList list;
        for (int i = 0; i < column; i++) {
            list << query.value(i).toString();
        }
        content << list.join(";");
    }
    return content;
}

void frmSimple::on_btnXls_clicked()
{
    //設(shè)置結(jié)構(gòu)體數(shù)據(jù)
    DataContent dataContent;
    //填充內(nèi)容
    dataContent.content = getContent();
    //設(shè)置列名列寬
    dataContent.columnNames = columnNames;
    dataContent.columnWidths = columnWidths;
    //設(shè)置文件名
    dataContent.fileName = "d:/0.xls";
    //設(shè)置表名
    dataContent.sheetName = "測試信息";

    //調(diào)用靜態(tài)函數(shù)保存
    DataXls::saveXls(dataContent);
    //打開剛才導(dǎo)出的文件
    QUIHelper::openFile(dataContent.fileName, "導(dǎo)出測試信息");
}

到此這篇關(guān)于Qt實現(xiàn)數(shù)據(jù)導(dǎo)出到xls的示例代碼的文章就介紹到這了,更多相關(guān)Qt數(shù)據(jù)導(dǎo)出到xls內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Qt 自定義分頁控件的實現(xiàn)

    Qt 自定義分頁控件的實現(xiàn)

    在應(yīng)用程序開發(fā)時經(jīng)常會遇到數(shù)據(jù)分頁的需求,每一頁展示特定數(shù)量的數(shù)據(jù),通過點擊按鈕翻頁或者輸入頁碼跳轉(zhuǎn)到指定頁,本文就來介紹一下Qt 自定義分頁控件的實現(xiàn),感興趣的可以了解一下
    2023-11-11
  • C++11中的chrono庫詳解

    C++11中的chrono庫詳解

    C++11提供了日期時間相關(guān)的庫chrono,通過chrono庫可以很方便的處理日期和時間,這篇文章主要介紹了C++11中的chrono庫,需要的朋友可以參考下
    2023-03-03
  • C++利用棧實現(xiàn)中綴表達式轉(zhuǎn)后綴表達式

    C++利用棧實現(xiàn)中綴表達式轉(zhuǎn)后綴表達式

    這篇文章主要為大家詳細介紹了C++利用棧實現(xiàn)中綴表達式轉(zhuǎn)后綴表達式,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • c++中的system(

    c++中的system("pause")的作用和含義解析

    這篇文章主要介紹了c++中system("pause")的作用和含義,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2018-03-03
  • c++實現(xiàn)獲取當(dāng)前時間(精確至秒,毫秒和微妙)

    c++實現(xiàn)獲取當(dāng)前時間(精確至秒,毫秒和微妙)

    這篇文章主要為大家詳細介紹了c++實現(xiàn)獲取當(dāng)前時間(可以精確至秒,毫秒和微妙)的相關(guān)知識,文中的示例代碼講解詳細,感興趣的小伙伴可以參考一下
    2023-11-11
  • Linux線程管理必備:解析互斥量與條件變量的詳解

    Linux線程管理必備:解析互斥量與條件變量的詳解

    本篇文章是對互斥量與條件變量的應(yīng)用進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • 基于C語言實現(xiàn)三子棋游戲的示例代碼

    基于C語言實現(xiàn)三子棋游戲的示例代碼

    這篇文章主要為大家詳細介紹了如何利用C語言數(shù)組實現(xiàn)簡單的三子棋游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • C++獲取當(dāng)前進程IAT的方法

    C++獲取當(dāng)前進程IAT的方法

    這篇文章主要介紹了C++獲取當(dāng)前進程IAT的方法,實例講述了IAT(導(dǎo)入地址表)的獲取方法,在Windows應(yīng)用程序開發(fā)中有著非常實用的應(yīng)用價值,需要的朋友可以參考下
    2014-10-10
  • 使用Libmicrohttpd搭建內(nèi)嵌(本地)服務(wù)器的方法

    使用Libmicrohttpd搭建內(nèi)嵌(本地)服務(wù)器的方法

    下面小編就為大家?guī)硪黄褂肔ibmicrohttpd搭建內(nèi)嵌(本地)服務(wù)器的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • C++內(nèi)存管理之簡易內(nèi)存池的實現(xiàn)

    C++內(nèi)存管理之簡易內(nèi)存池的實現(xiàn)

    大家好,本篇文章主要講的是C++內(nèi)存管理之簡易內(nèi)存池的實現(xiàn),感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下
    2021-12-12

最新評論