Pentaho Data Integration 界面开发

本文介绍如何使用XUL技术自定义PDI的用户界面,包括修改菜单栏和添加新菜单项。通过编辑menubar.xul文件可以实现界面的个性化,并详细解释了如何通过Spoon类响应菜单操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1,简介

PDI界面使用了xul技术。通过配置xul文件就可以修改界面了。其次,具体图形界面的开发也用到了eclipse swt 和 Jface包。本文记录如何修改PDI的主界面的菜单栏,并新添加的菜单栏上做一些操作。

2,PDI中的xul配置

主要的配置文件有两个spoon.xul 和 menubar.xul。它们在项目主目录的 ui 目录下。spoon.xul 中定义了主界面的菜单栏、工具栏,同时也引用了 menubar.xul

<pen:include src="menubar.xul" ignoreroot="true"/>

munubar.xul 用来定义主界面的菜单。修改menubar.xul就可以修改菜单栏了。

 此外,启动界面的修改主要在这里:

Splash splash = new Splash(display);

 

3,具体操作步骤

根据menubar.xul中已有的格式新增一个菜单栏:

<menuitem id="submit-to-storm" label="${Spoon.Menu.File.SubmitToStorm}" command="spoon.submitToStorm()" />

其中, id 将会在PDI的main 类 Spoon.java 中相关语句用到。id 用来定位此菜单栏。 label 表示在该菜单栏上显示的内容,为了国际化,使用了一个单独的message文件来保存内容,在

src\org\troy\di\ui\spoon\messages 目录下的 zh 文件中新增该菜单显示的内容即可。效果图如下:

 

再分析下PDI是如何解析xul文件的:

复制代码
1 mainSpoonContainer = xulLoader.loadXul(XUL_FILE_MAIN, new XulSpoonResourceBundle());//XUL_FILE_MAIN=spoon.xul
2 
3  mainSpoonContainer.addEventHandler(this);//add listener
4 
5 mainSpoonContainer.getDocumentRoot().getElementById("spoon-menubar");//add menubar
6 
7  mainToolbar = (XulToolbar) mainSpoonContainer.getDocumentRoot().getElementById("main-toolbar");//add toolbar
复制代码

 

增加了menu之后,那么点击该menu之后,如何响应呢?这是由menubar.xul中的 “command” 来定义。它指定了当点击menu时,在Spoon类中需要执行的方法。比如,可以在点击menu之后,弹出一个文件选择对话框,只需要在"command"指定的方法里面生成一个FileDialog即可。

String[] filterExtensions = {"*.ktr", "*.kjb"};//设置过滤文件
FileDialog dialog = new FileDialog(shell, SWT.OPEN);//生成一个文件对话框
dialog.setFilterExtensions(filterExtensions);
String fname = dialog.open();//fname 获得在文件对话框中选择了哪个文件的路径

这样,使用 fname 就可以对该文件进行进一步操作了。

 

4,PDI界面编程

PDI中的各种对话框、选择框……主要是用 eclipse swt 和 jface 包中的类来实现的。对于 eclipse swt 编程需要import 以下的包:

import org.eclipse.swt.*;
import org.eclipse.swt.widgets.*;

然后需要 Display对象和 Shell 对象持有 swt 中的各种组件。然后就可以往 shell 中添加各种组件了。

Display display = new Display(); 
Shell shell = new Shell(display);

 

5,PDI中的文件操作

PDI借助 Java IO包和 org.apache.commons.vfs 包 实现KettleVFS.java ,通过KettleVFS类来实现文件系统的各种操作。比如实现文件复制:

复制代码
 1         BufferedInputStream fis = null;
 2         BufferedOutputStream fos = null;
 3 
 4         try {
 5 
 6             fis = new BufferedInputStream(KettleVFS.getInputStream(in));
 7             fos = new BufferedOutputStream(KettleVFS.getOutputStream(out, false));
 8 
 9             byte[] buf = new byte[1024 * 1024]; // copy in chunks of 1 MB
10             int i = 0;
11             while ((i = fis.read(buf)) != -1) {
12                 fos.write(buf, 0, i);
13             }
14             fos.flush();
15             fos.close();
16             fis.close();
复制代码

 

5,参考资料

swt 编程参考文档


本文转自hapjin博客园博客,原文链接:http://www.cnblogs.com/hapjin/,如需转载请自行联系原作者

Pentaho Data Integration (PDI) 8.3 是一款功能强大的开源数据集成工具,广泛用于ETL(抽取、转换、加载)流程的构建和管理。以下是关于该版本的一些关键信息: ### 功能特性 Pentaho Data Integration 8.3 提供了多种功能来支持复杂的数据集成需求。这些功能包括但不限于: - **图形化界面**:通过 Spoon 工具,用户可以使用拖放的方式设计数据流任务。 - **丰富的输入/输出插件**:支持与各种数据库、文件格式(如CSV、Excel)、云平台以及大数据系统(如Hadoop、Spark)进行交互[^1]。 - **数据清洗与转换**:提供多种内置步骤来执行数据清洗、聚合、过滤、合并等操作。 - **调度与自动化**:可以通过作业(Jobs)实现任务的编排,并结合定时器或外部调度工具实现自动化运行。 - **增强的安全性**:支持基于角色的访问控制,确保敏感数据的安全性。 ### 使用方法 Pentaho Data Integration 8.3 的使用主要围绕两个核心概念展开:“转换”(Transformations)和“作业”(Jobs): - **转换**:定义单个数据处理步骤,例如从源系统中提取数据并将其转换为适合目标系统的格式。 - **作业**:将多个转换和其他任务组合在一起,以创建端到端的工作流。 此外,PDI 还支持脚本编写(如JavaScript、Python),允许开发人员根据具体需求自定义逻辑。对于更复杂的场景,还可以利用其API进行扩展开发。 ### 下载链接 Pentaho Data Integration 8.3 可以从 Pentaho 官方网站下载。不过需要注意的是,随着新版本的发布,旧版可能不再直接提供下载。在这种情况下,可以通过以下途径获取: - 访问 [Pentaho 官网](https://sourceforge.net/projects/pentaho/files/) 或者 [GitHub 仓库](https://github.com/pentaho/pentaho-kettle),查找历史版本存档。 - 查阅社区论坛和技术博客,有时会有人分享特定版本的下载链接或者安装包。 如果官方渠道无法找到所需版本,则建议考虑升级至最新稳定版,因为它们通常包含更多的改进和安全更新。 ```bash # 示例命令行启动 PDI Spoon ./spoon.sh ``` ### 相关问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值