1

ネストされたフィールドを含むプロパティ ファイルから JSON を作成する必要がありますか? たとえば、次のプロパティ ファイルがあります。

student.name="John"
student.exam.math=5
teacher.skills=10

出力には次の JSON ファイルが必要です。

Properties : {
    student : {
        name : "John",
        exam : {
            math : 5
        }
    },
    teacher : {
       skills : 10
    }
}

JSON コードは FLEX-JSON シリアライザーまたは GSON ライブラリで生成できますが、これは問題ではありません。主な問題は、プロパティを解析し、ネストされたプロパティを持つ Java オブジェクトまたはマップを生成することです。それを可能にするライブラリはありますか?ありがとう!

4

2 に答える 2

5

私の知る限り、それを行うためのよく知られたライブラリはありません。しかし、これは簡単な方法で行うことができます。

 public String propertiesToJson(Properties p) {
    Map tree = new LinkedHashMap();

    for (String name : p.stringPropertyNames()) {
        String[] parts = name.split("\\.");
        Map nextTree = tree;
        for (int i = 0, partsLength = parts.length; i < partsLength; i++) {
            String part = parts[i];
            Object v = nextTree.get(part);
            if (v == null) {
                if (i < partsLength - 1) {
                    Map newNextTree = new LinkedHashMap();
                    nextTree.put(part, newNextTree);
                    nextTree = newNextTree;
                } else {
                    nextTree.put(part, p.getProperty(name));
                }
            } else {
                if (i < partsLength - 1) {
                    nextTree = (Map) v;
                }
            }
        }
    }


    StringBuilder sb = new StringBuilder();
    sb.append("Properties : {\n");
    recursive(tree, sb, 1);
    sb.append("}");

    return sb.toString();
}

private void recursive(Map tree, StringBuilder sb, int deep) {
    boolean first = true;
    for (Object key : tree.keySet()) {
        if (!first) sb.append(",\n");
        else first = false;
        for (int t = 0; t < deep; t++) sb.append("\t");
        sb.append(key + " : ");
        Object v = tree.get(key);
        if (v instanceof Map) {
            sb.append("{\n");
            recursive((Map) v, sb, deep+1);
            for (int t = 0; t < deep; t++) sb.append("\t");
            sb.append("}");
        } else {
            sb.append(v);
        }
    }
    sb.append("\n");
}
于 2012-12-17T11:11:15.713 に答える