首页| 论坛| 消息

标题:Qt编写数据导出到Excel及Pdf和打印数据
作者:liudianwu
日期:2019-09-18 09:09
内容:

一、前言
用Qt开发已经九年了,期间用Qt做过不少的项目,在各种项目中有个功能很常用,尤其是涉及到数据记录存储的项目,那就是需要对查询的数据进行导出到Excel,或者导出到Pdf文件,或者直接打印查询的数据,其中导出数据到Excel最常见,基本上有三种方法。
方法一使用QAxObject,小数据量还可以,数据量一大直接懵逼,性能指数级下降,而且不支持跨平台,只能在WIN上玩一玩,对于大量的linux开发者来说,直接废了。
方法二使用第三方开源的QtXlsx,这个做的还是可以,使用人群也比较多,据说不依赖office组件跨平台的,缺点就是不支持xls格式,只支持高版本的xlsx,使用稍微比较繁琐,用户更多的需要的是直接一个函数传入对应的数据即可,越简单越好。
方法三使用csv格式作为导出数据,纯文本的数据存储格式,默认逗号作为分隔符,也可以指定其他符号作为分隔符,csv格式也是各种表格软件都支持的格式,相当轻便,作为各大系统或者平台和编程语言之间交互数据还是非常方便的,很多工业控制领域的软件都会采用这种格式,缺点就是太简单了,不能分组或者指定过滤条件特殊颜色显示等。
在对比了三种方式以后,决定自己造个轮子,主要是为了自身项目的需要写的,后面慢慢的客户需求多了,增加了通用常用场景的数据导出需求,目标要求至少包含三点:速度够快、使用够简洁、不依赖任何组件。
Demo示例地址:[https://pan.baidu.com/s/1uQsDQO5E5crUBN2J-nPeLQ](https://pan.baidu.com/s/1uQsDQO5E5crUBN2J-nPeLQ)提取码:1jkp名称:bin_dataout.zip
二、功能特点
1. 原创导出数据机制,不依赖任何office组件或者操作系统等第三方库,尤其是支持嵌入式linux。
2. 10万行数据9个字段只需要2秒钟完成。
3. 只需要四个步骤即可开始急速导出大量数据到Excel。
4. 同时提供直接写入数据接口和多线程写入数据接口,不卡主界面。
5. 可设置标题、副标题、表名。
6. 可设置字段名称、列宽度。
7. 可设置是否启用校验过滤数据、校验的列、校验规则、校验值,符合规则的特殊颜色显示。
8. 可设置随机背景颜色及需要随机背景色的列集合。
9. 支持分组输出数据,比如按照设备分组输出数据,方便查看。
10. 可自定义行内容分隔符。
11. 可追加数据形式写入数据,建议每次追加的数据小于10000条。
12. 灵活性超高,可自由更改源码设置对齐方式、文字颜色、背景颜色等。
13. 支持任意excel表格软件, ..


#1 [圣域天子 09-18 10:00]
有源码不?
#2 [alan66 09-18 10:12]
有源码吗?
#3 回 alan66 的帖子 [佛山无影脚 09-18 10:15]
alan66:有源码吗? (2019-09-18 10:12) 
需要money的
#4 [mengkun 09-18 10:56]
原理是输出的文件实际是一个 xml 格式(纯文本),然后将后缀名改为了 “.xls” 伪装成 Excel 格式
很不错的思路,学习了!
#5 回 mengkun 的帖子 [liudianwu 09-18 11:13]
mengkun:
原理是输出的文件实际是一个 xml 格式(纯文本),然后将后缀名改为了 “.xls” 伪装成 Excel 格式
很不错的思路,学习了! (2019-09-18 10:56) 
是的,openxls

<< 1 2 3 >> (1/3)

回复 发表
主题 版块