`
dilantaya
  • 浏览: 101667 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

报表导出解决方案,包括延时导出和即时导出

 
阅读更多
/**
	 * 根据sql,csv标题,csv内容,csv名称,报表名称,报表编号,报表压缩文件夹名称,返回报表地址(本地导出、延迟导出)
	 * 
	 * @param sql
	 *            需导出、统计SQL
	 * @param csvTitle
	 *            csv文档中标题
	 * @param classProperty
	 *            csv文档中标题
	 * @param rpt_nm
	 *            报表名称
	 * @param rpt_cd
	 *            报表编号
	 * @param args
	 *            Class
	 * @return String
	 */
	public String exprotCvs(String sql, String csvTitle, String classProperty,
			String rpt_nm, String rpt_cd, Class args) {
		String filePath = "";
		int iTotalCount = baseDao.getResultCount(sql);
		if (iTotalCount >= iBatchSize) { // 导出条数大于需批量导出条数时,记录该SQL,转为延迟处理
			UserRpt userRpt = new UserRpt();
			long id = SequenceManager.getKey(UserRpt.SEQUENCE); // 报表ID
			userRpt.setId(id);
			userRpt.setUser_cd("test"); // test
			userRpt.setStatus("0"); // 运行状态-"0未运行"
			userRpt.setRpt_nm(rpt_nm); // 报表名称
			userRpt.setRpt_cd(rpt_cd); // 报表编号
			userRpt.setCrt_dt(AQPDateUtil.generateTime()); // 创建时间
			userRpt.setRpt_desc("记录数:" + String.valueOf(iTotalCount)); // 备注描述
			baseDao.insertRpt(userRpt); // 新增一条用户报表信息
			insertRptSql(sql, id); // 新增若干条用户报表SQL信息
			return "@" + id;
		}
		List totalResult = baseDao.queryAllBySql(sql, args);
		if (iTotalCount <= iPageSize) { // 导出条数小于CSV最大条数时,导出单个CSV
			filePath = getCsvPath(totalResult, csvTitle, classProperty, rpt_cd);
			return filePath;
		}
		List result = AQPUtil.getListResult(totalResult, iPageSize); // 根据单个CSV最大条数,将总结果集拆分为若干个封装在List中
		String[] sFilePath = new String[result.size()];
		for (int i = 0; i < result.size(); i++) {
			sFilePath[i] = this.getCsvPath((List) result.get(i), csvTitle,
					classProperty, rpt_cd);
		}
		filePath = FilePathUtil.zipFiles(sFilePath, AQPDateUtil.generateTime()
				+ "_" + rpt_cd + ".zip");
		return filePath;
	}

	/**
	 * 根据sql,csv标题,csv内容,csv名称,报表编号,报表压缩文件夹名称,返回报表地址(联机导出)
	 * 
	 * @param sql
	 *            需导出、统计SQL
	 * @param csvTitle
	 *            csv文档中标题
	 * @param classProperty
	 *            csv文档中标题
	 * @param rpt_cd
	 *            报表编号
	 * @param args
	 *            Class
	 * @return String
	 */
	public String exprotTP(String sql, String csvTitle, String classProperty,
			String rpt_cd, Class args) {
		String filePath = "";
		List result = null;
		int iTotalCount = baseDao.getResultCount(sql);
		int iCsvSize = iTotalCount / iPageSize;
		if (iTotalCount % iPageSize > 0) {// 如果不能取整,则总页数加一
			iCsvSize++;
		}
		String[] sFilePath = new String[iCsvSize];
		for (int i = 0; i < iCsvSize; i++) {
			result = new ArrayList();
			String pageSql = baseDao.getQueryPageSql(sql, i + 1, iPageSize);
			result = baseDao.queryAllBySql(pageSql, args);
			sFilePath[i] = this.getCsvPath(result, csvTitle, classProperty,
					rpt_cd);
		}
		filePath = FilePathUtil.zipFiles(sFilePath, AQPDateUtil.generateTime()
				+ "_" + rpt_cd + ".zip");
		return filePath;
	}

	/**
	 * 根据List结果集,csv标题,csv内容,csv名称,返回导出csv本地路径
	 * 
	 * @param result
	 *            查询出List列表
	 * @param csvTitle
	 *            csv文档中标题
	 * @param classProperty
	 *            csv标题内容
	 * @param csvCode
	 *            导出csv名称
	 * @return String 导出csv本地路径
	 */
	public String getCsvPath(List result, String csvTitle,
			String classProperty, String csvCode) {
		FileObject fileObject = FilePathUtil.getFileObject(csvCode + ".csv");
		try {
			fileObject.writeLine(csvTitle);
			CsvLineUtil csvLine = new CsvLineUtil();
			Object obj = null;
			Collection<String> collection = AQPUtil
					.getCollectionPeroperty(classProperty);
			if (collection.size() != csvTitle.split(",").length) {
				throw new DpcaRuntimeException("", "CSV中标题及内容长度不一致!");
			}
			int idx = 1;
			for (int i = 0; i < result.size(); i++) {
				obj = new Object();
				obj = (Object) result.get(i);
				csvLine.initFieldsData(collection.size());
				String strProperty = null;
				for (Iterator<String> iter = collection.iterator(); iter
						.hasNext();) {
					strProperty = iter.next();
					csvLine.setFieldData(idx, (String) AQPUtil
							.getObjectProperty(obj, strProperty));
					idx++;
					if (idx - 1 == collection.size()) {
						fileObject.writeLine(csvLine.getData());
						idx = 1;
					}
				}
			}
		} catch (Exception e) {
			e.printStackTrace();
			throw new DpcaRuntimeException("", e.getMessage());
		} finally {
			fileObject.close();
		}
		return fileObject.getAbsolutepath();
	}

分享到:
评论

相关推荐

    Facebook模拟登录爬取群组成员信息并导出excel

    在本项目中,我们主要探讨如何使用Java进行Facebook模拟登录,并爬取群组成员信息,最后将这些数据导出到Excel文件中。这个任务涉及到网络爬虫技术、模拟登录、数据解析以及文件导出等多个方面的知识。以下是相关...

    TimeLapse 延时摄影工具

    【标题】"TimeLapse 延时摄影工具"是一个专为摄影爱好者...综上所述,"TimeLapse 延时摄影工具"结合了OpenCV的强大图像处理能力,为用户提供了全面的延时摄影解决方案,从拍摄规划到后期制作,覆盖了延时摄影的全过程。

    delphi延时函数 动态链接库DLL函数

    例如,我们创建一个包含延时函数的DLL: ```delphi library DelayDLL; uses System.Classes; procedure Delay; stdcall; var Milliseconds: DWORD; begin // 获取DLL函数参数 asm mov Milliseconds, EAX ...

    Quartus中的延时分析

    延时信息可以通过VHDL、Verilog以及标准延迟文件(SDF)的形式导出到其他EDA工具中。 #### 四、单时钟系统的延时分析 ##### 1. 寄存器性能 - **内部fmax**:设计中每个时钟的最大频率。 - **设置时间**:输入信号相...

    基于ssm的兴趣班和延时班管理系统设计与实现.zip

    同时,该系统还支持课程的录入和安排,学费的收取和统计,报表的生成和导出等功能。此外,系统还能够提供各种报表和分析功能,方便学校管理人员进行数据分析和决策。 该系统的优点在于其便捷性和灵活性。学校管理...

    导入PIN DELAY 的方法

    指定要导出的芯片以及存储位置和文件名。 2. **对比数据**:打开导出的文件并与原始PIN DELAY文件进行对比。如果文件中存在空格,需要先使用查找和替换功能移除这些空格。 3. **使用VLOOKUP函数**:利用Excel的VLOOK...

    LRT5.0延时视频去闪软件

    为了解决这个问题,"LRT5.0延时视频去闪软件"应运而生。 LRTimelapse是一款专为Adobe Lightroom定制的延时摄影后期处理工具,它的全称是LRTimelapse 5.0.4。该软件能够有效地去除延时视频中的闪烁问题,提供平滑的...

    关于延时摄影的制作流程

    延时摄影是一种特殊的摄影技术,通过长时间连续拍摄一系列照片,然后快速播放,使得原本缓慢变化的场景呈现出动态的视觉效果。下面将详细讲解延时摄影的制作流程。 首先,你需要准备必要的硬件设备,包括一台支持...

    智慧体育馆总体解决方案PPT(109页).pdf

    智慧体育场馆信息化整体建设解决方案通过集成先进的音视频技术和智能管理系统,不仅提升了体育赛事的组织和执行效率,也为观众提供了更加丰富和高质量的观赛体验。随着技术的不断进步和创新,智慧体育场馆将成为体育...

    智慧体育场馆信息化整体建设解决方案PPT(49页).pptx

    智慧体育场馆信息化整体建设解决方案通过集成先进的音视频技术和智能管理系统,不仅提升了体育赛事的组织和执行效率,也为观众提供了更加丰富和高质量的观赛体验。随着技术的不断进步和创新,智慧体育场馆将成为体育...

    延时作品欣赏合集.rar

    4. **导出与分享**:最后,将制作完成的延时视频导出为常见的视频格式,如MP4、MOV等,然后可以上传到社交媒体或者个人作品集供他人欣赏和学习。 延时摄影的魅力在于它能捕捉到肉眼无法直观感知的动态美,通过技术...

    体育馆行业音视频系统建设与应用解决方案PPT(41页).pptx

    智慧体育场馆信息化整体建设解决方案通过集成先进的音视频技术和智能管理系统,不仅提升了体育赛事的组织和执行效率,也为观众提供了更加丰富和高质量的观赛体验。随着技术的不断进步和创新,智慧体育场馆将成为体育...

    延时摄影后期软件LRTimelapse和 lightroom操作流程图文教程.doc

    在延时摄影的后期制作中,LRTimelapse 和 Adobe Lightroom 是两个常用的软件,它们可以帮助摄影师处理曝光曲线、色彩调整等关键步骤,以达到理想的效果。 LRTimelapse 是一款专门针对延时摄影的后期处理软件,它...

    20210702-国泰君安-机构客户交易场景系列2:三方接入解决方案.pdf

    1. 三方接入解决方案的组成和作用: - 三方接入拓补结构:指的是一种分布式网络结构,使交易系统、三方接入网关和客户系统之间通过网络进行数据交换与业务处理。 - 三方接入网关:作为连接交易系统和客户系统的...

    延时摄影后期软件LRTimelapse和-lightroom操作流程图文教程.doc

    《延时摄影后期处理:LRTimelapse与Lightroom的综合运用》 延时摄影是一种独特的摄影技术,它通过连续拍摄多张照片并快速播放来展现时间的流逝。...通过熟练掌握这一流程,你将能够提升延时摄影作品的艺术性和专业性。

    Java爬取网页信息,并导出到Excel

    在本文中,我们将深入探讨如何使用Java编程语言来爬取网页信息,并将其导出到Excel文件。这是一个实用的技能,特别是在数据分析、市场研究或者自动化报告生成等场景中。首先,我们需要了解Java爬虫的基本概念,然后...

    sciencedirect 网站抓取过程.docx

    本文档详细介绍了 sciencedirect 网站抓取过程,包括开发环境、软件使用教程、爬虫解决方案、数据处理、日志显示等方面的知识点。 一、开发环境 本文档使用 C# 语言作为开发语言,并使用 SQLite 作为数据库管理...

    南网13版集中器现场调试软件简要说明.pdf

    系统配置包括终端通信延时、BCD码解析地址、修改系统配置最大测量点取值限制为1000等。 终端(集中器)档案管理 终端(集中器)档案管理包括手动管理及批量管理,管理终端通信档案参数及普通、中继任务、抄表通道...

    P2P网络中污染扩散的流模型ppt

    这些流体模型可导出一系列非线性的微分方程,通过这些微分方程,获得了封闭的解决方案。 文章同时还分析了“自由下载”和“用户中途放弃”等两种用户行为对污染信息扩散的影响,此外,还分析了版本偏好,黑名单等...

Global site tag (gtag.js) - Google Analytics