RCP项目_poi下载Excel

2024-02-11 12:32
文章标签 excel 项目 下载 poi rcp

本文主要是介绍RCP项目_poi下载Excel,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

poi所用的包:
poi-3.8-20120326.jar
poi-examples-3.8-20120326.jar
poi-excelant-3.8-20120326.jar
poi-ooxml-3.8-20120326.jar
poi-ooxml-schemas-3.8-20120326.jar
poi-scratchpad-3.8-20120326.jar
xmlbeans-2.3.0.jar
xwork-core-2.2.1.1.jar
注意:要在plugin.xml文件的Runtime中的ClassPath加入包,没有加载会访问不到
/**
* 存储sheet的数据
* @author suhuafu
*
*/
public class PaperDataVO {
public PaperDataVO() {
}
public PaperDataVO(String workbookName, List<String[]> list) {
this.workbookName = workbookName;
this.list = list;
}
private String workbookName="default";//工作表名称
private List<String[]> list = new ArrayList<String[]>();//动态值队
public String getWorkbookName() {
return workbookName;
}


 

 

@Override
public void widgetSelected(SelectionEvent e) {
int count = table.getColumnCount();
TableItem[] items =  table.getItems();
final List<String[]> list = new ArrayList<String[]>();
String[] str = null; 
for (int i = 0; i < items.length; i++) {
str = new String[count];
for (int j = 0; j < count; j++) {
str[j] = items[i].getText(j);
}
list.add(str);
}
//创建文件夹对话框
DirectoryDialog  direcory = new DirectoryDialog(getSite().getShell());
direcory.open();
final String path = direcory.getFilterPath();
//打开处理窗口
ProgressMonitorDialog pmd = new ProgressMonitorDialog(getSite().getShell());  
//创建进度条对象
IRunnableWithProgress rwp = new IRunnableWithProgress() {
@Override  
public void run(IProgressMonitor monitor){  
//totalWork为IProgressMonitor.UNKNOWN时表示不知道任务的总量   
//将在进度条上显示一个来回移动的进度条   
monitor.beginTask("正在下载..." , IProgressMonitor.UNKNOWN); 
//TODO 相应的业务逻辑  
monitor.subTask("读取数据...");
if(path != ""){
List<PaperDataVO> pdvs = new ArrayList<PaperDataVO>();
PaperDataVO paper = new PaperDataVO();
paper.setWorkbookName("报销单");
paper.setList(list);
pdvs.add(paper);
OutputStream tempOut = null;
InputStream in = null;
try {
//获取插件,获取文件的相对路径
in = Platform.getBundle("com.welldell.rcp.render.db")
.getEntry("fileTemplate/renderMain.xlsx").openStream();
//生成文件路径
String src = path+"\\报销单"+ 
DateFormatUtil.formatDateToString(new Date(System.currentTimeMillis()), DateFormatUtil.V_LONG_YMD) +".xlsx";
tempOut = new FileOutputStream(src);
WriteExcelUtil.buildExcel(in, tempOut, pdvs);
} catch (FileNotFoundException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} catch (IOException ioe) {
// TODO Auto-generated catch block
ioe.printStackTrace();
}
}
monitor.subTask("处理完成!");
monitor.done();  
}
};  
try {
pmd.run(true, false, rwp);
} catch (Exception e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}  
}
});


 

public static void buildExcel(InputStream ins, OutputStream os, List<PaperDataVO> pdvs) {
if (pdvs == null || pdvs.size() == 0) {
return;
}
try {
Sheet sheet = null;
Row row = null;//行
Cell cell = null;//单元格
Workbook wb = new XSSFWorkbook(ins);
int sheetNum = wb.getActiveSheetIndex();//模板sheet的数量
for (int i = 0; i < pdvs.size(); i++) {
PaperDataVO pdv =  pdvs.get(i);
if(sheetNum < i){
sheet = wb.getSheetAt(wb.getActiveSheetIndex());//获取激活中的sheet
}else{
sheet = wb.getSheetAt(i);
if(sheet == null)
sheet = wb.createSheet(pdv.getWorkbookName()+i);
}
List<String[]> list = pdv.getList();
int rowNum = list.size()+1;
int cellNum = sheet.getRow(0).getPhysicalNumberOfCells();
for (int j = 1; j < rowNum ; j++) {//循环行
row = sheet.createRow(j);
for (int k = 0; k < cellNum; k++) {//循环行的列
cell = row.createCell(k);
cell.setCellValue(list.get(j-1)[k]);
}
}
}
wb.write(os);
os.flush();
os.close();
} catch (Exception ex) {
ex.printStackTrace();
}
}


 

这篇关于RCP项目_poi下载Excel的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/699782

相关文章

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat

Python多线程实现大文件快速下载的代码实现

《Python多线程实现大文件快速下载的代码实现》在互联网时代,文件下载是日常操作之一,尤其是大文件,然而,网络条件不稳定或带宽有限时,下载速度会变得很慢,本文将介绍如何使用Python实现多线程下载... 目录引言一、多线程下载原理二、python实现多线程下载代码说明:三、实战案例四、注意事项五、总结引

Springboot项目构建时各种依赖详细介绍与依赖关系说明详解

《Springboot项目构建时各种依赖详细介绍与依赖关系说明详解》SpringBoot通过spring-boot-dependencies统一依赖版本管理,spring-boot-starter-w... 目录一、spring-boot-dependencies1.简介2. 内容概览3.核心内容结构4.

C#使用Spire.XLS快速生成多表格Excel文件

《C#使用Spire.XLS快速生成多表格Excel文件》在日常开发中,我们经常需要将业务数据导出为结构清晰的Excel文件,本文将手把手教你使用Spire.XLS这个强大的.NET组件,只需几行C#... 目录一、Spire.XLS核心优势清单1.1 性能碾压:从3秒到0.5秒的质变1.2 批量操作的优雅

在ASP.NET项目中如何使用C#生成二维码

《在ASP.NET项目中如何使用C#生成二维码》二维码(QRCode)已广泛应用于网址分享,支付链接等场景,本文将以ASP.NET为示例,演示如何实现输入文本/URL,生成二维码,在线显示与下载的完整... 目录创建前端页面(Index.cshtml)后端二维码生成逻辑(Index.cshtml.cs)总结