在【核心对象】-【脚本】下有个【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暂时还不支持