Kettle中调用用户自定义的jar包

在使用kettle过程中,有些功能是kettle不提供的,这样就需要想办法,不过kettle中的java代码可以解决大部分问题,下边就展示使用java代码组件调用自己编写的jar包的过程

1,创建java-jar包

package test;

import java.io.BufferedWriter;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;

public class TestFun {
	public String to_upper(String str)
	{
		String str1=str.toUpperCase();
		BufferedWriter writer = null;  
        File file = new File("d:\\dat\\"+ "aaa" + ".json");  
        //如果文件不存在,则新建一个  
        if(!file.exists()){  
            try {  
                file.createNewFile();  
            } catch (IOException e) {  
                e.printStackTrace();  
            }  
        }  
        //写入  
        try {  
            writer = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(file,false), "UTF-8"));  
            writer.write("aaa");  
        } catch (IOException e) {  
            e.printStackTrace();  
        }finally {  
            try {  
                if(writer != null){  
                    writer.close();  
                }  
            } catch (IOException e) {  
                e.printStackTrace();  
            }  
        }  
		return str1;
	}
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		TestFun tf = new TestFun();
		System.out.println(tf.to_upper("china"));
	}

}

调试,没问题后,导出jar



2,将jar包放入kettle中的lib目录,并重启kettle

3,创建ktr并测试

整体流程

其中从数据库中输入表行,经过java代码处理输出为文本文件

其中java代码内容如下:

//package com.tools.ws;
import test.TestFun;


public boolean processRow(StepMetaInterface smi, StepDataInterface sdi) throws KettleException
{
  		Object[] r = getRow();
    	// If the row object is null, we are done processing.
		if (r == null) {
			setOutputDone();
			return false;
		}
		
		//if(first){
		//	first = false;
		//}

		TestFun tf = new TestFun();
		
		r = createOutputRow(r, data.outputRowMeta.size());
		String inputstr = get(Fields.In,"str").getString(r);
		String upperstr = tf.to_upper(inputstr);
		String upperstr2 = inputstr.toUpperCase();
		get(Fields.Out, "outputstr1").setValue(r, upperstr);
		get(Fields.Out, "outputstr2").setValue(r, upperstr2);
		putRow(data.outputRowMeta, r);

		return true;
}

以下是截图


测试截图:


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

朝闻道-夕死可矣

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值