kettle的java脚本及java数据类型与kettle数据类型对应

public boolean processRow(StepMetaInterface smi, StepDataInterface sdi) throws KettleException
{
Object[] r = getRow();
if (r == null) {
setOutputDone();
return false;
}


    if (first)
    {
        first = false;
    }

String La = get(Fields.In, "Lat").getString(r);
String Lo = get(Fields.In, "Lon").getString(r);


    Double LaDouble = Double.parseDouble(La);
    Double LoDouble = Double.parseDouble(Lo);
    
    


   // La = La+"---123";
   // Lo = Lo+"---456";
   


    get(Fields.In, "Lon").setValue(r, Lo);
    get(Fields.In, "Lat").setValue(r, La);




get(Fields.In, "newL").setValue(r, LaDouble);


    putRow(data.outputRowMeta, r);


return true;

}


获得变量:String La = get(Fields.In, "Lat").getString(r);  

保存变量:get(Fields.In, "Lat").setValue(r, La);   保存变量的存入的字段名如Lat,必须在流中已经存在

kettle的java脚本及java数据类型与kettle数据类型对应_第1张图片

字段对应:

源代码中:

case ValueMetaInterface.TYPE_STRING : parameterType = String.class; break; 
case ValueMetaInterface.TYPE_NUMBER : parameterType = Double.class; break; 
case ValueMetaInterface.TYPE_INTEGER : parameterType = Long.class; break; 
case ValueMetaInterface.TYPE_DATE : parameterType = Date.class; break; 
case ValueMetaInterface.TYPE_BIGNUMBER : parameterType = BigDecimal.class; break; 
case ValueMetaInterface.TYPE_BOOLEAN : parameterType = Boolean.class; break; 
case ValueMetaInterface.TYPE_BINARY : parameterType = byte[].class; break; 

简单来说,就是: 
STRING : String.class 
NUMBER : Double.class 
INTEGER : Long.class 
DATE : Date.class 
BIGNUMBER : BigDecimal.class 
BOOLEAN : Boolean.class 
BINARY : byte[].class

转自:http://z7kevin.iteye.com/blog/2070954


你可能感兴趣的:(kettle)