常用效果(六) : 格式化json 日志


从网上摘抄的,很方便。


package com.hanya.financing.global.utils;

import android.util.Log;

import com.hanya.financing.global.WalrusApplication;


public class DebugUtil {
    public static boolean DEBUG = WalrusApplication.isShowLog;
    public static String className;

    private DebugUtil() {
    }

    public static boolean isDebugEnable() {
        return DEBUG;
    }

    private static String createLog(String log) {
        return log;
    }

    private static void getMethodNames(StackTraceElement[] sElements) {
        String methodName = sElements[1].getMethodName();
        int lineNumber = sElements[1].getLineNumber();
        className = "{ " + sElements[1].getFileName() + " : " + lineNumber + " - " + methodName + " }";
    }

    public static void e(String message) {
        if (!isDebugEnable())
            return;

        getMethodNames(new Throwable().getStackTrace());
        Log.e(className, createLog(message));
    }

    public static void e(String tag, String message, Throwable throwable) {
        if (!isDebugEnable()) {
            return;
        }
        Log.e(tag, message, throwable);
    }

    public static void e(String Tag, String message) {
        if (!isDebugEnable())
            return;

        getMethodNames(new Throwable().getStackTrace());
        Log.e(Tag, createLog(message));
    }

    public static void i(String message) {
        if (!isDebugEnable())
            return;

        getMethodNames(new Throwable().getStackTrace());
        Log.i(className, createLog(message));
    }

    public static void d(String message) {
        if (!isDebugEnable())
            return;

        getMethodNames(new Throwable().getStackTrace());
        Log.d(className, createLog(message));
    }

    public static void v(String message) {
        if (!isDebugEnable())
            return;

        getMethodNames(new Throwable().getStackTrace());
        Log.v(className, createLog(message));
    }

    public static void w(String message) {
        if (!isDebugEnable())
            return;

        getMethodNames(new Throwable().getStackTrace());
        Log.w(className, createLog(message));
    }

    public static void wtf(String message) {
        if (!isDebugEnable())
            return;

        getMethodNames(new Throwable().getStackTrace());
        Log.wtf(className, createLog(message));
    }

    public static void debug(String tag, Object searchManager) {
        if (isDebugEnable()) {
            Log.d(tag, searchManager.toString());
        }
    }

    public static void trace(String s) {
        if (isDebugEnable()) {
            Log.v("", s);
        }
    }

    public static void warn(String tag, Object intent) {
        if (isDebugEnable()) {
            Log.e(tag, intent.toString());
        }
    }

    /**
     * 该类提供格式化JSON字符串的方法。
     * 该类的方法formatJson将JSON字符串格式化,方便查看JSON数据。
     * <p>例如:
     * <p>JSON字符串:["yht","xzj","zwy"]
     * <p>格式化为:
     * <p>[
     * <p>     "yht",
     * <p>     "xzj",
     * <p>     "zwy"
     * <p>]
     * <p/>
     * <p>使用算法如下:
     * <p>对输入字符串,追个字符的遍历
     * <p>1、获取当前字符。
     * <p>2、如果当前字符是前方括号、前花括号做如下处理:
     * <p>(1)如果前面还有字符,并且字符为“:”,打印:换行和缩进字符字符串。
     * <p>(2)打印:当前字符。
     * <p>(3)前方括号、前花括号,的后面必须换行。打印:换行。
     * <p>(4)每出现一次前方括号、前花括号;缩进次数增加一次。打印:新行缩进。
     * <p>(5)进行下一次循环。
     * <p>3、如果当前字符是后方括号、后花括号做如下处理:
     * <p>(1)后方括号、后花括号,的前面必须换行。打印:换行。
     * <p>(2)每出现一次后方括号、后花括号;缩进次数减少一次。打印:缩进。
     * <p>(3)打印:当前字符。
     * <p>(4)如果当前字符后面还有字符,并且字符不为“,”,打印:换行。
     * <p>(5)继续下一次循环。
     * <p>4、如果当前字符是逗号。逗号后面换行,并缩进,不改变缩进次数。
     * <p>5、打印:当前字符。
     *
     * @author yanghaitao
     * @version [版本号, 2014年9月29日]
     */
    public static class JsonFormatTool {
        /**
         * 单位缩进字符串。
         */
        private static String SPACE = "   ";

        /**
         * 返回格式化JSON字符串。
         *
         * @param json 未格式化的JSON字符串。
         * @return 格式化的JSON字符串。
         */
        public String formatJson(String json) {
            StringBuilder result = new StringBuilder();

            int length = json.length();
            int number = 0;
            char key;

            //遍历输入字符串。
            for (int i = 0; i < length; i++) {
                //1、获取当前字符。
                key = json.charAt(i);

                //2、如果当前字符是前方括号、前花括号做如下处理:
                if ((key == '[') || (key == '{')) {
                    //(1)如果前面还有字符,并且字符为“:”,打印:换行和缩进字符字符串。
                    if ((i - 1 > 0) && (json.charAt(i - 1) == ':')) {
                        result.append('\n');
                        result.append(indent(number));
                    }

                    //(2)打印:当前字符。
                    result.append(key);

                    //(3)前方括号、前花括号,的后面必须换行。打印:换行。
                    result.append('\n');

                    //(4)每出现一次前方括号、前花括号;缩进次数增加一次。打印:新行缩进。
                    number++;
                    result.append(indent(number));

                    //(5)进行下一次循环。
                    continue;
                }

                //3、如果当前字符是后方括号、后花括号做如下处理:
                if ((key == ']') || (key == '}')) {
                    //(1)后方括号、后花括号,的前面必须换行。打印:换行。
                    result.append('\n');

                    //(2)每出现一次后方括号、后花括号;缩进次数减少一次。打印:缩进。
                    number--;
                    result.append(indent(number));

                    //(3)打印:当前字符。
                    result.append(key);

                    //(4)如果当前字符后面还有字符,并且字符不为“,”,打印:换行。
                    if (((i + 1) < length) && (json.charAt(i + 1) != ',')) {
                        result.append('\n');
                    }

                    //(5)继续下一次循环。
                    continue;
                }

                //4、如果当前字符是逗号。逗号后面换行,并缩进,不改变缩进次数。
                if ((key == ',')) {
                    result.append(key);
                    result.append('\n');
                    result.append(indent(number));
                    continue;
                }

                //5、打印:当前字符。
                result.append(key);
            }

            return result.toString();
        }

        /**
         * 返回指定次数的缩进字符串。每一次缩进三个空格,即SPACE。
         *
         * @param number 缩进次数。
         * @return 指定缩进次数的字符串。
         */
        private String indent(int number) {
            StringBuilder result = new StringBuilder();
            for (int i = 0; i < number; i++) {
                result.append(SPACE);
            }
            return result.toString();
        }
    }
}




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值