多表批量导出txt及打压缩包下载
在一些特殊的业务系统中,有些客户查看报表数据时不需要在浏览器上逐一查看,需要在页面端选择要查看的报表名称(可多选),选择条件,然后将所选中的报表批量导出到txt文件中并且要把批量导出的结果文件打成压缩包下载,这样就能在其他时间统一查看报表数据。
解决方案:润乾提供了丰富的开发接口,可通过API实现该需求。
String raqNames="1,2";//批量导出报表名称,此处可从其他页面获得
String burs="BDP";//定义参数,可从其他页面获得
String root = getServletContext().getRealPath("/"); //获得应用根目录
String fileName = "srbbfx";//定义批量导出压缩包名称
String txtPath = root+"txtPath\\"+Double.toString(Math.random()*100000000).toString().substring(0,6)+"\\";
java.io.File file = new java.io.File(txtPath);
if(!file.exists()) {
file.mkdirs();
} else {
}
//报表导出后涉及到打压缩包下载,此处为每次导出新建临时文件夹
Context context = new Context();//构建报表环境
context.setParamValue("date1","20101101");//设置起始时间
context.setParamValue("date2","20101231");//设置结束时间,实际应用由程序获得或循环取值
context.setMacroValue("macro1"," and bur_sta_tel='"+bur[j]+"'");//给润乾宏赋值,每次取相应站数据
Engine enging = new Engine( rd, context);//构建润乾引擎
IReport iReport = enging.calc();//计算报表,生成结果文件
java.io.FileOutputStream fos=new FileOutputStream(txtPath+"b"+raqN[i]+bur[j]+"20101101"+".txt");
//txt文件名称格式
报表文件名:b+表名+单位代码+日.txt
ReportUtils.exportToText(fos,iReport,",",true);//导出txt文件
//将导出的txt文件放到待压缩的zip包中
String filePath=txtPath+"b"+raqN[i]+bur[j]+"20101101"+".txt";
File f = new File(filePath);
if(f.exists())
{
FileInputStream fis1 = new FileInputStream(f);
ZipEntry ze = new ZipEntry(f.getName());
zos.putNextEntry(ze);
int b;
while((b = fis1.read()) != -1)
zos.write(b);
fis1.close();
}
fos.flush();
fos.close();
}
}
zos.flush();
zos.close();
//将生成的压缩包下载到客户端,此处可自写代码实现,可自增代码将生成的文件删除
response.addHeader("Content-Disposition", "attachment; filename=\"" + fileName+".zip"+ "\"");
try
{
java.io.OutputStream os = response.getOutputStream();
java.io.FileInputStream fiss = new java.io.FileInputStream(txtPath+fileName+".zip");
byte[] b = new byte[10240];
int i = 0;
while ( (i = fiss.read(b)) > 0 )
{
os.write(b, 0, i);
}
fiss.close();
os.flush();
os.close();
}
catch ( Exception e )
{}
out.clear();
out = pageContext.pushBody();
这样报表就能实现批量导出txt并打压缩包下载。
具体代码见附件。打压缩包用到了其他类,将附件中的jar包放到WEB-INF/lib下,这里为导出txt文件,导出其他文件类似
多表批量导出txt及打压缩包下载的更多相关文章
- asp.net用zip方法批量导出txt
首先: 引用 ICSharpCode.SharpZipLib.dll,百度下载 然后引用命名空间: using ICSharpCode.SharpZipLib.Zip;using ICSharpCod ...
- 批量导出access某表内容到word文档
一.需求: 需要将表中每一条记录中的某些内容导出在一个word文档中,并将这些文档保存在指定文件夹目录下 二.界面,简单设计如下: 三.添加office相关引用 添加后可在解决方案资源管理器中看到: ...
- 批量导出数据库表(oracle)
批量导出数据库表(oracle) 要求:导出sql文件,包含表结构和数据. 方案一 1:用cmd进入命令行输入:tnsping cmstar就是测试172.18.13.200是否连接成功2:导入与导出 ...
- C# 导出word文档及批量导出word文档(1)
这里用到了两个dll,一个是aspose.word.dll,另外一个是ICSharpCode.SharpZipLib.dll,ICSharpCode.SharpZipLib.dll是用于批量 ...
- C# 导出word文档及批量导出word文档(4)
接下来是批量导出word文档和批量打印word文件,批量导出word文档和批量打印word文件的思路差不多,只是批量打印不用打包压缩文件,而是把所有文件合成一个word,然后通过js来调用 ...
- ajax+ashx:实现文件的批量导出
背景: 最近公司有一个需求,就是实现excle的批量导出(一次性导出多个excle). 实现方式: 想到的实现方式: 1.发起一个导出请求,然后批量生产需要导出的excle文件,最后将文件生成一个压缩 ...
- Gitlab用户信息批量导出
前言 因运维体系中涉及到用户权限管理及统计,需将Gitlab用户数据提取出来并录入到公司内部自建的权限统计平台. 本文将对Gitlab的用户信息数据批量导出进行操作说明! 思路 A)要对数据进行批量的 ...
- Oracle sqlldr导入导出txt数据文件详解
一.sqlldr导入txt 1.预备 a).txt文件 这里要保存成无签名的UTF-8 b).oracle建表 2.编写控制文件input_test.ctl LOAD DATA CHARACTERSE ...
- 解决Oracle 11g在用EXP导出时,空表不能导出
实践结论可行,看"2.解决办法" 一.问题原因: 11G中有个新特性,当表无数据时,不分配segment,以节省空间 1.insert一行,再rollback就产生 ...
随机推荐
- SQL实现数据行列转换
前言: 在日常的工作中,使用数据库查看数据是很经常的事,数据库的数据非常多,如果此时的数据设计是一行行的设计话,就会有多行同一个用户的数据,查看起来比较费劲,如果数据较多时,不方便查看,为了更加方便工 ...
- constructor 属性返回变量或对象的构造函数。判断是否为日期,数组的例子
constructor 属性返回变量或对象的构造函数. <!DOCTYPE html> <html> <head> <meta charset="u ...
- JavaScript函数理解
本文参考自简书javaScript之函数详解 这里从函数的构造函数开始. 在js中,函数都是对象,它们都是Function构造函数的实例.因此,类似Java中的对象,函数名可以理解为指向该Functi ...
- J06-Java IO流总结六 《 BufferedReader和BufferedWriter 》
1. 概念简介 与字节缓冲流BufferedInputStream和BufferedOutputStream对应的,我们还有字符缓冲流BufferedReader和BufferedWriter,顾名思 ...
- (转)MySQL 常用数据存储引擎区别
MySQL 常用数据存储引擎区别 原文:https://laravel-china.org/articles/4198/mysql-common-data-storage-engine mysql有多 ...
- C++ 实现Biginteger
网上C++版Biginteger参差不齐,一下子没有找到一个令人满意Biginteger,最近用c++改写了一下C#版 BigInteger,可以用于RSA大素数的生成,分享给大家.也请大家批评指正改 ...
- JavaScript中的异步操作
什么是异步操作? 异步模式并不难理解,比如任务A.B.C,执行A之后执行B,但是B是一个耗时的工作,所以,把B放在任务队列中,去执行C,然后B的一些I/O等返回结果之后,再去执行B,这就是异步操作. ...
- eclipse 首次使用配置
这里是eclipse neo版本的配置 1.设置workspace 首次启动,选择指定的工作空间(workspace),用于存放java代码.
- 初学者必知的Python中优雅的用法 分类: Python 2015-05-11 15:02 782人阅读 评论(0) 收藏
本文由 伯乐在线 - 淘小米 翻译,Daetalus 校稿.未经许可,禁止转载!英文出处:freepythontips.wordpress.com.欢迎加入翻译小组. Hi 朋友们.由于我最近都比较忙 ...
- DotNetOpenAuth 服务端搭建
新建项目: 安装DotNetOpenAuth: 新增OAuthController: 代码如下: public class OAuthController : Controller { private ...