亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Qt數據導出的方法是什么

發布時間:2021-12-15 14:00:11 來源:億速云 閱讀:396 作者:iii 欄目:互聯網科技

這篇文章主要介紹“Qt數據導出的方法是什么”,在日常操作中,相信很多人在Qt數據導出的方法是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Qt數據導出的方法是什么”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

一、前言

數據導出一般指導出到excel表格,可能有部分用戶還需要導出到pdf,因為pdf基本上不可編輯,防止用戶重新編輯導出的數據,excel可能絕大部分用過電腦的人都知道,廣為流行,主要就是微軟的office軟件和金山的wps軟件,所以只要涉及到導出數據的軟件,基本上默認都是導出到excel,以便領導或者其他非軟件專業人士打開看數據,或者二次分析數據,Qt中沒有數據導出到excel相關的類,有一些第三方開源的比如qtxlsx、libxls等,很多初學者首先選擇的是用qaxobject來調用excel的組件實現導出數據,這種方法比較原始,但是也功能強大,只要是excel接口提供的,都能實現,比如導出特定的圖形等,缺點就是慢,速度真慢,幾十萬百萬的數據量導出,卡出屎,說白了效率比較低,關鍵還不能跨平臺,只能在WIN上,到了其他系統全部歇菜,而Qt的大量應用場景在linux系統,這也是Qt的起步發家的地方,而qtxlsx、libxls就很好的解決了這個問題,跨平臺。

通用數據導出組件功能特點:

  1. 原創導出數據機制,不依賴任何office組件或者操作系統等第三方庫,尤其是支持嵌入式linux。

  2. 10萬行數據9個字段只需要2秒鐘完成。

  3. 只需要四個步驟即可開始急速導出大量數據到Excel。

  4. 同時提供直接寫入數據接口和多線程寫入數據接口,不卡主界面。

  5. 可設置標題、副標題、表名。

  6. 可設置字段名稱、列寬度。

  7. 可設置是否啟用校驗過濾數據、校驗的列、校驗規則、校驗值,符合規則的特殊顏色顯示。

  8. 可設置隨機背景顏色及需要隨機背景色的列集合。

  9. 支持分組輸出數據,比如按照設備分組輸出數據,方便查看。

  10. 可自定義行內容分隔符。

  11. 可追加數據形式寫入數據,建議每次追加的數據小于10000條。

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

  13. 支持任意excel表格軟件,包括但不限于excel2003/2007/2010/2013/2017/wps/openoffice等。

  14. 除了提供導出到Excel類以外,還提供導出到Pdf文件以及打印數據的類。

  15. 注釋完善,詳細完整的使用demo,支持QTableWidget、QTableView、數據庫三種數據源。

  16. 純Qt編寫,支持任意Qt版本+任意編譯器+任意系統。

二、功能特點

  1. 采集數據端口,支持串口端口+網絡端口,串口支持自由設置串口號+波特率,網絡支持自由設置IP地址+通訊端口,每個端口支持采集周期,默認1秒鐘一個地址,支持設置通訊超時次數,默認3次,支持最大重連時間,用于重新讀取離線的設備。

  2. 控制器信息,能夠添加控制器名稱,選擇控制器地址+控制器型號,設置該控制器下面的探測器數量。

  3. 探測器信息,能夠添加位號,可自由選擇探測器型號,氣體種類,氣體符號,高報值,低報值,緩沖值,清零值,是否啟用,報警聲音,背景地圖,存儲周期,數值換算小數點位數,報警延時時間,報警的類型(HH,LL,HL)等。

  4. 控制器型號+探測器型號+氣體種類+氣體符號,均可自由配置。

  5. 地圖支持導入和刪除,所有的探測器對應地圖位置可自由拖動保存。

  6. 端口信息+控制器信息+探測器信息,支持導入導出+導出到excel+打印。

  7. 運行記錄+報警記錄+用戶記錄,支持多條件組合查詢,比如時間段+控制器+探測器等,所有記錄支持導出到excel+打印。

  8. 導出到excel的記錄支持所有excel+wps等表格文件版本,不依賴excel等軟件。

  9. 可刪除指定時間范圍內的數據,支持自動清理早期數據,設置最大保存記錄數。

  10. 支持報警短信轉發,支持多個接收手機號碼,可設定發送間隔,比如即時發送或者6個小時發送一次所有的報警信息,短信內容過長,自動拆分多條短信。

  11. 支持報警郵件轉發,支持多個接收郵箱,可設定發送間隔,比如即時發送或者6個小時發送一次所有的報警信息,支持附件發送。

  12. 高報顏色+低報顏色+正常顏色+0值顏色+曲線背景+曲線顏色等,都可以自由選擇。

  13. 軟件的中文標題+英文標題+logo路徑+版權所有都可以自由設置。

  14. 提供開關設置開機運行+報警聲音+自動登錄+記住密碼等。

  15. 報警聲音可設置播放次數,界面提供17種皮膚文件選擇。

  16. 支持云端數據同步,可設置云端數據庫的信息,比如數據庫名稱,用戶名+密碼等。

  17. 支持網絡轉發和網絡接收,網絡接收開啟后,軟件從udp接收數據進行解析。網絡轉發支持多個目標IP,這樣就實現了本地采集的軟件,自由將數據轉到客戶端,隨時查看探測器數據。

  18. 自動記住用戶最后停留的界面+其他信息,重啟后自動應用。

  19. 報警自動切換到對應的地圖,探測器按鈕閃爍。

  20. 雙擊探測器圖標,可以進行回控。

  21. 支持用戶權限管理,管理員+操作員兩大類,用戶登錄+用戶退出,可以記住密碼和自動登錄,超過三次報錯提示并關閉程序。

  22. 支持四種監控模式,設備面板監控+地圖監控+表格數據監控+曲線數據監控,可自由切換,四種同步應用。

  23. 支持報警繼電器聯動,一個位號可以跨串口聯動多個模塊和繼電器號,支持多對多。

  24. 本地數據存儲支持sqlite+mysql,支持遠程數據同步到云端數據庫。自動重連。

  25. 本地設備采集到的數據實時上傳到云端,以便手機APP或者web等其他方式提取。

  26. 支持兩種數據源,一種是串口和網絡通過協議采集設備數據,一種是數據庫采集。數據庫采集模式可以作為通用的系統使用。

  27. 自帶設備模擬工具,支持16個設備數據模擬,同時還帶數據庫數據模擬,以便在沒有設備的時候測試數據。

  28. 默認通信協議采用modbus協議,后期增加mqtt等物聯網協議的支持,做成通用系統。

  29. 支持所有windows操作系統+linux操作系統和其他操作系統。

三、效果圖

Qt數據導出的方法是什么 Qt數據導出的方法是什么

四、核心代碼

void frmDataAlarm::on_btnExcel_clicked()
{
    //先判斷行數,超過一定大小彈出提示
    QString str = ui->labResultCount->text();
    QStringList list = str.split(" ");
    int rowCount = list.at(1).toInt();
    if (rowCount > 100000) {
        QUIHelper::showMessageBoxError("不支持大量數據,請重新查詢!", 3);
        return;
    }

    if (rowCount > 10000) {
        QString msg = QString("要導出的數據共 %1 條,請耐心等待!確定要導出數據嗎?").arg(rowCount);
        if (QUIHelper::showMessageBoxQuestion(msg) != QMessageBox::Yes) {
            return;
        }
    }

    QString fileName = API::getFileName("保存文件(*.xls)", QUIHelper::appPath() + "/db", QString("alarmlog_%1.xls").arg(STRDATETIME));
    if (fileName.isEmpty()) {
        return;
    }

    //設定導出數據字段及排序字段
    QString columns = "LogID,PositionID,DeviceName,NodeName,NodeValue,NodeSign,Content,StartTime,ConfirmUser,ConfirmTime,ConfirmContent";
    QString where = whereSql + " order by " + QString("LogID %1").arg(App::AlarmLogOrder);
    QStringList content = DBHelper::getContent("AlarmLog", columns, where, "", ";");

    QList<QString> columnNames;
    QList<int> columnWidths;
    columnNames << "編號" << "位號" << "控制器名稱" << "探測器名稱" << "報警值" << "單位" << "報警類型"
                << "觸發時間" << "確認用戶" << "確認時間" << "確認信息";
    columnWidths << 50 << 80 << 120 << 100 << 50 << 50 << 100 << 135 << 80 << 135 << 120;

    QString name = ui->ckNodeName->isChecked() ? ui->cboxNodeName->currentText() : "所有探測器";
    QString type = name + "報警記錄";
    ExcelAPI::Instance()->saveExcel(fileName, type, type, "", columnNames, columnWidths, content);

    QString msg = QString("導出%1").arg(type);
    DBHelper::addUserLog(msg);

    if (QUIHelper::showMessageBoxQuestion(msg + "成功!確定現在就打開嗎?") == QMessageBox::Yes) {
        QString url = QString("file:///%1").arg(fileName);
        QDesktopServices::openUrl(QUrl(url, QUrl::TolerantMode));
    }
}

到此,關于“Qt數據導出的方法是什么”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

qt
AI

泾阳县| 吉隆县| 镇宁| 临西县| 教育| 阳谷县| 琼中| 昌平区| 新竹县| 营口市| 容城县| 林州市| 清水河县| 黑水县| 津市市| 嘉禾县| 东乌珠穆沁旗| 集贤县| 海林市| 乡宁县| 巨野县| 城固县| 平泉县| 招远市| 工布江达县| 浦江县| 蓝山县| 苍溪县| 任丘市| 平昌县| 大渡口区| 清涧县| 金华市| 鸡东县| 南平市| 句容市| 闸北区| 深水埗区| 都兰县| 眉山市| 阳新县|