kettle的自定义java类控件User Defined Java Class

在【核心对象】-【脚本】下有个【User Defined Java Class】插件,功能很强大,允许自己在这里写java代码,其中用到了一个jar包,janino,有兴趣的自己上网去搜。janino只支持jdk 1.4,所以只能在【User Defined Java Class】里写jdk 1.4的代码,泛型这些是不支持的了。

把【User Defined Java Class】拖出来后双击打开,然后再双击左边的【Code Snippits】-【Common use】-【Main】,出现如下代码
public boolean processRow(StepMetaInterface smi, StepDataInterface sdi) throws KettleException
{
	Object[] r = getRow();
	if (r == null) {
		setOutputDone();
		return false;
	}

    if (first)
    {
        first = false;
    }

	// It is always safest to call createOutputRow() to ensure that your output row's Object[] is large
    // enough to handle any new fields you are creating in this step.
    r = createOutputRow(r, outputRowSize);
	
    /* TODO: Your code here. (See Sample)
    
    // Get the value from an input field
    String foobar = get(Fields.In, "a_fieldname").getString(r);

    foobar += "bar";
    
    // Set a value in a new output field
    get(Fields.Out, "output_fieldname").setValue(r, foobar);

	*/
	// Send the row on to the next step.
    putRow(data.outputRowMeta, r);

	return true;
}

点确定窗口关闭,之后再打开,发现左边的【Input fields】和【Output fields】下都是显示“Getting fields...please wait”,这算是kettle的一个bug吧,因为代码有问题,编译不通过。
这一行代码
r = createOutputRow(r, outputRowSize);

outputRowSize这个变量不存在,可以改为
r = createOutputRow(r, data.outputRowMeta.size());

或在前面加上
int outputRowSize = data.outputRowMeta.size();

即可,点确定关闭窗口再打开就可以发现【Input fields】和【Output fields】下有显示输入输出字段了。

另外,打开窗口,在右侧的【Class code】的标题栏右键,可以增加一个自定义java类,但是没用,因为现在还不支持在一个自定义java类中引用另一个自定义java类,所以写了多个自定义java类也没用,kettle暂时还不支持

你可能感兴趣的:(Kettle)