All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.aliyun.odps.commons.util.CostResultParser Maven / Gradle / Ivy

There is a newer version: 0.51.5-public
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */

package com.aliyun.odps.commons.util;

import java.util.Map;

import com.aliyun.odps.utils.GsonObjectBuilder;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;

/**
 * Cost计费预测模式结果解析器
 *
 * @author zhenyi.zzy
 */
public class CostResultParser {

  private static String LINE_SEPARATOR = System.getProperty("line.separator");

  /**
   * 对约定的Cost结果进行解析,若解析失败则直接将原结果返回;若解析成功则返回解析后的内容
   * 约定格式为:
   * 
   *     {
   *        "Cost": {
   *           : {
   *             : ,
   *             : ,
   *             ...
   *           }
   *        }
   *     }
   * 
* 例如SQL的result为: *
   *     {
   *        "Cost": {
   *           "SQL": {
   *             "Input": "1840",
   *             "UDF": "0",
   *             "Complexity": "1.0"
   *           }
   *        }
   *     }
   * 
* @param result * @param taskType * @return */ public static String parse(String result, String taskType) { Map node = null; try { Gson gson = GsonObjectBuilder.get(); Map cost = gson.fromJson(result, Map.class); node = (Map) ((Map) cost.get("Cost")).get(taskType); } catch (Exception e) { return result; } if (node == null) { return result; } StringBuffer sb = new StringBuffer(); for (Map.Entry entry : node.entrySet()) { if ("Input".equalsIgnoreCase(entry.getKey())) { sb.append(String.format("%s:%s Bytes", entry.getKey(), entry.getValue())) .append(LINE_SEPARATOR); } else { sb.append(String.format("%s:%s", entry.getKey(), entry.getValue())).append(LINE_SEPARATOR); } } if (sb.toString().isEmpty()) { return result; } else { return sb.toString(); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy