您好,登錄后才能下訂單哦!
這篇文章的內容主要圍繞Qt數據庫應用中如何將數據打印到pdf進行講述,文章內容清晰易懂,條理清晰,非常適合新手學習,值得大家去閱讀。感興趣的朋友可以跟隨小編一起閱讀吧。希望大家通過這篇文章有所收獲!
自從數據可以導出到xls,又有客戶提出了不同的需求,比如既然可以將數據導出到xls,那是否可以導出到pdf文件呢?因為xls打開以后用戶可以修改數據造假之類的,而pdf默認是不可編輯的,除非借助專業的工具,所以如果想要限定用戶導出數據不能被更改,那導出pdf是最佳選擇。寫程序往往都是這樣,一步步慢慢增加,隨著用戶需求的增加,程序量也越來越多,輪子組件也越來越多。往往客戶提需求的時候,一定要認真聆聽,尤其是一線用戶,實際使用的用戶,盡管有些不合理的需求,但是能滿足就盡量滿足,畢竟客戶就是上帝。
在Qt中要導出到pdf必須要用到qprinter類,相當于這些數據是打印到pdf的,所以確切點是叫打印到pdf文件,而不是導出數據到pdf,格式這塊由于采用的是打印,所以需要用html嵌套table表格的形式來打印,支持的格式就有限了,一般可以設置字體大小、顏色、邊框、對齊等,盡管是html,但是也是支持有限的html格式,這點要特別注意。現在的qt版本貌似單獨將pdf提煉出來成了獨立的模塊,功能更強大。
結構體支持的參數:
文件名稱
表名
主標題
副標題
字段名稱集合
字段寬度集合
內容集合
行內容分隔符
子內容分隔符
邊框寬度
校驗列
校驗類型
校驗值
檢驗顏色
最后列拉伸填充
橫向排版
紙張邊距
組件同時集成了導出數據到csv、xls、pdf和打印數據。
所有操作全部提供靜態方法無需new,數據和屬性等各種參數設置采用結構體數據,極為方便。
同時支持QTableView、QTableWidget、QStandardItemModel、QSqlTableModel等數據源。
提供靜態方法直接傳入QTableView、QTableWidget控件,自動識別列名、列寬和數據內容。
每組功能都提供單獨的完整的示例,注釋詳細,非常適合各階段Qter程序員。
原創導出數據機制,不依賴任何office組件或者操作系統等第三方庫,支持嵌入式linux。
速度超快,9個字段10萬行數據只需要2秒鐘完成。
只需要四個步驟即可開始急速導出海量數據比如100W條記錄到Excel。
同時提供直接寫入數據接口和多線程寫入數據接口,不卡主界面。
可設置標題、副標題、表名。
可設置導出數據的字段名、列名、列寬。
可設置末尾列自動拉伸填充,默認拉伸更美觀。
可設置是否啟用校驗過濾數據,啟用后符合規則的數據特殊顏色顯示。
可指定校驗的列、校驗規則、校驗值、校驗值數據類型。
校驗規則支持 精確等于==、大于>、大于等于>=、小于<、小于等于<=、不等于!=、包含contains。
校驗值數據類型支持 整型int、浮點型float、雙精度型double,默認文本字符串類型。
可設置隨機背景顏色及需要隨機背景色的列集合。
支持分組輸出數據,比如按照設備分組輸出數據,方便查看。
可設置csv分隔符、行內容分隔符、子內容分隔符。
可設置邊框寬度、自動填數據類型,默認自動數據類型開啟。
可設置是否開啟數據單元格樣式,默認不開啟,不開啟可以節約大概30%的文件體積。
可設置橫向排版、紙張邊距等,比如導出到pdf以及打印數據。
支持圖文混排導出數據到pdf以及打印數據,自動分頁。
靈活性超高,可自由更改源碼設置對齊方式、文字顏色、背景顏色等。
支持任意excel表格軟件,包括但不限于excel2003-2021、wps、openoffice等。
純Qt編寫,支持任意Qt版本+任意編譯器+任意系統。
體驗地址:https://pan.baidu.com/s/1ZxG-oyUKe286LPMPxOrO2A 提取碼:o05q 文件名:bin_dataout.zip
國內站點:https://gitee.com/feiyangqingyun
國際站點:https://github.com/feiyangqingyun
QString DataHelper::DataOut(quint8 type, const QString &file, const QString &title, const QString &sheet, const QStringList &content, const QStringList &columnNames, const QList<int> &columnWidths) { //設置結構體數據 DataContent dataContent; //填充內容 dataContent.content = content; //設置列名列寬 dataContent.columnNames = columnNames; dataContent.columnWidths = columnWidths; //設置標題 dataContent.title = title; //如果是導出數據則先判斷文件名稱是否為空,為空則彈出文件對話框選擇 QString fileName = file; if (fileName.isEmpty() && type < 3) { //不同的格式后綴 QString filter = "all files (*.*)"; if (type == 0) { filter = "csv files (*.csv)"; } else if (type == 1) { filter = "xls files (*.xls)"; } else if (type == 2) { filter = "pdf files (*.pdf)"; } fileName = QFileDialog::getSaveFileName(0, "選擇保存文件", "", filter); if (fileName.isEmpty()) { return fileName; } } //設置文件名 dataContent.fileName = fileName; //xls還需要設置表名 dataContent.sheetName = sheet; //調用靜態函數 if (type == 0) { //重新組織內容,前面寫入標題,分隔符換成csv的定義的分隔符 QStringList list; //把標題加到內容中 list << columnNames.join(DataCsv::CsvSpliter); //重新更換分隔符 foreach (QString text, content) { text.replace(";", DataCsv::CsvSpliter); list << text; } DataCsv::outputData(fileName, list); } else if (type == 1) { DataXls::saveXls(dataContent); } else if (type == 2) { DataPrint::savePdf(dataContent); } else if (type == 3) { DataPrint::print(dataContent); } return fileName; }
感謝你的閱讀,相信你對“Qt數據庫應用中如何將數據打印到pdf”這一問題有一定的了解,快去動手實踐吧,如果想了解更多相關知識點,可以關注億速云網站!小編會繼續為大家帶來更好的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。