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

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

常用的jdk下载地址

jdk下载地址 安装方式可以看之前的博客: mac安装jdk oracle 版本:https://www.oracle.com/java/technologies/downloads/ Eclipse Temurin版本:https://adoptium.net/zh-CN/temurin/releases/ 阿里版本: github:https://github.com/

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

SpringBoot项目是如何启动

启动步骤 概念 运行main方法,初始化SpringApplication 从spring.factories读取listener ApplicationContentInitializer运行run方法读取环境变量,配置信息创建SpringApplication上下文预初始化上下文,将启动类作为配置类进行读取调用 refresh 加载 IOC容器,加载所有的自动配置类,创建容器在这个过程

Maven创建项目中的groupId, artifactId, 和 version的意思

文章目录 groupIdartifactIdversionname groupId 定义:groupId 是 Maven 项目坐标的第一个部分,它通常表示项目的组织或公司的域名反转写法。例如,如果你为公司 example.com 开发软件,groupId 可能是 com.example。作用:groupId 被用来组织和分组相关的 Maven artifacts,这样可以避免

2. 下载rknn-toolkit2项目

官网链接: https://github.com/airockchip/rknn-toolkit2 安装好git:[[1. Git的安装]] 下载项目: git clone https://github.com/airockchip/rknn-toolkit2.git 或者直接去github下载压缩文件,解压即可。

9.8javaweb项目总结

1.主界面用户信息显示 登录成功后,将用户信息存储在记录在 localStorage中,然后进入界面之前通过js来渲染主界面 存储用户信息 将用户信息渲染在主界面上,并且头像设置跳转,到个人资料界面 这里数据库中还没有设置相关信息 2.模糊查找 检测输入框是否有变更,有的话调用方法,进行查找 发送检测请求,然后接收的时候设置最多显示四个类似的搜索结果

maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令

maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令 在日常的工作中由于各种原因,会出现这样一种情况,某些项目并没有打包至mvnrepository。如果采用原始直接打包放到lib目录的方式进行处理,便对项目的管理带来一些不必要的麻烦。例如版本升级后需要重新打包并,替换原有jar包等等一些额外的工作量和麻烦。为了避免这些不必要的麻烦,通常我们