码迷,mamicode.com
首页 > Web开发 > 详细

Kettle 使用Json输入

时间:2018-01-25 11:09:24      阅读:1289      评论:0      收藏:0      [点我收藏+]

标签:分享图片   smi   private   uva   ret   .com   body   divide   value   

 import java.math.BigDecimal;
 private static final String JD="jd";
 private static final String WD="wd";

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

        //维度
        String wdstr = get(Fields.In, WD).getString(r);
        //经度
        String jdstr = get(Fields.In, JD).getString(r);
        if(!isArray(wdstr)||!isArray(jdstr)){
           return true;
        }
        get(Fields.Out, WD).setValue(r, getCovNewVlaue(wdstr));
        get(Fields.Out, JD).setValue(r, getCovNewVlaue(jdstr));

        putRow(data.outputRowMeta, r);
        return true;
  }

 private double getCovNewVlaue(String dustr) {
        String replace =  dustr.replace("N", "").replace("E", "");
        String[] duArray = replace.split(" ");
        double duValue = Double.parseDouble(duArray[0]);
        double minuteValue = Double.parseDouble(duArray[1]);
        double secondValue = Double.parseDouble(duArray[2]);

        BigDecimal minute = BigDecimal.valueOf(minuteValue).divide(BigDecimal.valueOf(60), 10,
                BigDecimal.ROUND_HALF_DOWN);
        BigDecimal second = BigDecimal.valueOf(secondValue).divide(BigDecimal.valueOf(3600), 10,
                BigDecimal.ROUND_HALF_DOWN);
        BigDecimal newVlaue = BigDecimal.valueOf(duValue).add(minute).add(second);
        return newVlaue.doubleValue();
    }

 private boolean isArray(String dustr){
        return dustr.split(" ").length==1?false:true;
 }

技术分享图片

 

Kettle 使用Json输入

标签:分享图片   smi   private   uva   ret   .com   body   divide   value   

原文地址:https://www.cnblogs.com/justuntil/p/8349628.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!