- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个普通的 json 字符串要解析:
"name":"Jake",
"salary":3000,
"phones":[{"phoneType":"cell","phoneNumber":"111-111-111"},
{"phoneType":"work","phoneNumber":"222-222-222"}],
"taskIds":[11,22,33],
"address":{"street":"101 Blue Dr","city":"White Smoke"}}
public class Model {
private long id;
private String nodeName;
private String nodeType;
private String nodeValue;
private Model parent;
}
public class TreeModelParser {
static List<Model> models = new ArrayList<Model>();
static Model model;
static int id = 0;
static boolean first = true;
static int nbr = 0;
static int nbr2 = 0;
static List<JsonNode> parsedNodes;
public static void main(String[] args) throws IOException {
String inputJson = "{\"name\":\"Jake\",\"salary\":3000,\"phones\":"
+ "[{\"phoneType\":\"cell\",\"phoneNumber\":\"111-111-111\"},"
+ "{\"phoneType\":\"work\",\"phoneNumber\":\"222-222-222\"}]," + "\"taskIds\":[11,22,33],"
+ "\"address\":{\"street\":\"101 Blue Dr\",\"city\":\"White Smoke\"}}";
ObjectMapper objectMapper = new ObjectMapper();
JsonNode rootNode = objectMapper.readTree(inputJson);
models = new ArrayList<Model>();
model = new Model();
traverse(rootNode, 1);
for (Model mod : models) {
System.out.println(
mod.getId() + "-" + mod.getNodeName() + "-" + mod.getNodeType() + "-" + mod.getNodeValue());
}
}
private static void traverse(JsonNode node, int level) {
if (node.getNodeType() == JsonNodeType.ARRAY) {
traverseArray(node, level);
} else if (node.getNodeType() == JsonNodeType.OBJECT) {
traverseObject(node, level);
} else {
throw new RuntimeException("Not yet implemented");
}
}
private static void traverseObject(JsonNode node, int level) {
Iterator<String> fieldNames = node.fieldNames();
List<String> lst = getListFromIterator(fieldNames);
for (String fieldName : lst) {
JsonNode childNode = node.get(fieldName);
printNode(childNode, fieldName, level);
if (traversable(childNode)) {
traverse(childNode, level + 1);
}
}
}
private static void traverseArray(JsonNode node, int level) {
for (JsonNode jsonArrayNode : node) {
printNode(jsonArrayNode, "arrayElement", level);
if (traversable(jsonArrayNode)) {
traverse(jsonArrayNode, level + 1);
}
}
}
private static boolean traversable(JsonNode node) {
return node.getNodeType() == JsonNodeType.OBJECT || node.getNodeType() == JsonNodeType.ARRAY;
}
private static void printNode(JsonNode node, String keyName, int level) {
model = new Model();
id++;
model.setId(id);
model.setNodeName(keyName);
if (node.getNodeType().equals(JsonNodeType.ARRAY)) {
model.setNodeType("ARRAY");
} else if (node.getNodeType().equals(JsonNodeType.STRING)) {
model.setNodeType("STRING");
} else if (node.getNodeType().equals(JsonNodeType.NUMBER)) {
model.setNodeType("NUMBER");
} else if (node.getNodeType().equals(JsonNodeType.OBJECT)) {
model.setNodeType("OBJECT");
} else if (node.getNodeType().equals(JsonNodeType.BOOLEAN)) {
model.setNodeType("BOOLEAN");
}
if (traversable(node)) {
} else {
Object value = null;
if (node.isTextual()) {
value = node.textValue();
model.setNodeValue((String) value);
} else if (node.isNumber()) {
value = node.numberValue();
model.setNodeValue((Number) value + "");
}
}
models.add(model);
}
public static List<String> getListFromIterator(Iterator<String> iterator) {
List<String> list = new ArrayList<>();
iterator.forEachRemaining(list::add);
return list;
}
}
1-name-STRING-Jake-null
2-salary-NUMBER-3000-null
3-phones-ARRAY-null-null
4-arrayElement-OBJECT-null-null
5-phoneType-STRING-cell-null
6-phoneNumber-STRING-111-111-111-null
7-arrayElement-OBJECT-null-null
8-phoneType-STRING-work-null
9-phoneNumber-STRING-222-222-222-null
10-taskIds-ARRAY-null-null
11-arrayElement-NUMBER-11-null
12-arrayElement-NUMBER-22-null
13-arrayElement-NUMBER-33-null
14-address-OBJECT-null-null
15-street-STRING-101 Blue Dr-null
16-city-STRING-White Smoke-null
最佳答案
如果我们搬家会容易得多List<Model> models
和 Model model
属性来处理并在每次需要时传递它们。而不是通过 level
这不是必需的,我们可以通过 Model parent
参数将是给定节点的父对象:
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.node.JsonNodeType;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
public class JsonModelApp {
public static void main(String[] args) throws Exception {
String inputJson = "{\"name\":\"Jake\",\"salary\":3000,\"phones\":"
+ "[{\"phoneType\":\"cell\",\"phoneNumber\":\"111-111-111\"},"
+ "{\"phoneType\":\"work\",\"phoneNumber\":\"222-222-222\"}]," + "\"taskIds\":[11,22,33],"
+ "\"address\":{\"street\":\"101 Blue Dr\",\"city\":\"White Smoke\"}}";
ObjectMapper objectMapper = new ObjectMapper();
JsonNode rootNode = objectMapper.readTree(inputJson);
List<Model> models = new TreeModelParser().traverse(rootNode);
for (Model mod : models) {
System.out.println(mod + " => Parent: " + mod.getParent());
}
}
}
class TreeModelParser {
private int id = 0;
public List<Model> traverse(JsonNode root) {
Model parent = new Model();
parent.setNodeName("ROOT");
List<Model> models = new ArrayList<>();
traverse(models, root, parent);
return models;
}
private void traverse(List<Model> models, JsonNode node, Model parent) {
if (node.getNodeType() == JsonNodeType.ARRAY) {
traverseArray(models, node, parent);
} else if (node.getNodeType() == JsonNodeType.OBJECT) {
traverseObject(models, node, parent);
} else {
throw new RuntimeException("Not yet implemented");
}
}
private void traverseObject(List<Model> models, JsonNode node, Model parent) {
Iterator<String> fieldNames = node.fieldNames();
List<String> lst = getListFromIterator(fieldNames);
for (String fieldName : lst) {
JsonNode childNode = node.get(fieldName);
Model model = createModel(childNode, fieldName, parent);
models.add(model);
if (traversable(childNode)) {
traverse(models, childNode, model);
}
}
}
private void traverseArray(List<Model> models, JsonNode node, Model parent) {
for (JsonNode jsonArrayNode : node) {
Model model = createModel(jsonArrayNode, "arrayElement", parent);
models.add(model);
if (traversable(jsonArrayNode)) {
traverse(models, jsonArrayNode, model);
}
}
}
private static boolean traversable(JsonNode node) {
return node.getNodeType() == JsonNodeType.OBJECT || node.getNodeType() == JsonNodeType.ARRAY;
}
private Model createModel(JsonNode node, String keyName, Model parent) {
Model model = new Model();
model.setId(++id);
model.setNodeName(keyName);
model.setParent(parent);
if (node.getNodeType().equals(JsonNodeType.ARRAY)) {
model.setNodeType("ARRAY");
} else if (node.getNodeType().equals(JsonNodeType.STRING)) {
model.setNodeType("STRING");
} else if (node.getNodeType().equals(JsonNodeType.NUMBER)) {
model.setNodeType("NUMBER");
} else if (node.getNodeType().equals(JsonNodeType.OBJECT)) {
model.setNodeType("OBJECT");
} else if (node.getNodeType().equals(JsonNodeType.BOOLEAN)) {
model.setNodeType("BOOLEAN");
}
if (!traversable(node)) {
Object value;
if (node.isTextual()) {
value = node.textValue();
model.setNodeValue((String) value);
} else if (node.isNumber()) {
value = node.numberValue();
model.setNodeValue(value + "");
}
}
return model;
}
private static List<String> getListFromIterator(Iterator<String> iterator) {
List<String> list = new ArrayList<>();
iterator.forEachRemaining(list::add);
return list;
}
}
class Model {
private long id;
private String nodeName;
private String nodeType;
private String nodeValue;
private Model parent;
public long getId() {
return id;
}
public void setId(long id) {
this.id = id;
}
public String getNodeName() {
return nodeName;
}
public void setNodeName(String nodeName) {
this.nodeName = nodeName;
}
public String getNodeType() {
return nodeType;
}
public void setNodeType(String nodeType) {
this.nodeType = nodeType;
}
public String getNodeValue() {
return nodeValue;
}
public void setNodeValue(String nodeValue) {
this.nodeValue = nodeValue;
}
public Model getParent() {
return parent;
}
public void setParent(Model parent) {
this.parent = parent;
}
@Override
public String toString() {
final StringBuilder sb = new StringBuilder("Model{");
sb.append("id=").append(id);
sb.append(", nodeName='").append(nodeName).append('\'');
sb.append(", nodeType='").append(nodeType).append('\'');
if (nodeValue != null) {
sb.append(", nodeValue='").append(nodeValue).append('\'');
}
sb.append('}');
return sb.toString();
}
}
Model{id=1, nodeName='name', nodeType='STRING', nodeValue='Jake'} => Parent: Model{id=0, nodeName='ROOT', nodeType='null'}
Model{id=2, nodeName='salary', nodeType='NUMBER', nodeValue='3000'} => Parent: Model{id=0, nodeName='ROOT', nodeType='null'}
Model{id=3, nodeName='phones', nodeType='ARRAY'} => Parent: Model{id=0, nodeName='ROOT', nodeType='null'}
Model{id=4, nodeName='arrayElement', nodeType='OBJECT'} => Parent: Model{id=3, nodeName='phones', nodeType='ARRAY'}
Model{id=5, nodeName='phoneType', nodeType='STRING', nodeValue='cell'} => Parent: Model{id=4, nodeName='arrayElement', nodeType='OBJECT'}
Model{id=6, nodeName='phoneNumber', nodeType='STRING', nodeValue='111-111-111'} => Parent: Model{id=4, nodeName='arrayElement', nodeType='OBJECT'}
Model{id=7, nodeName='arrayElement', nodeType='OBJECT'} => Parent: Model{id=3, nodeName='phones', nodeType='ARRAY'}
Model{id=8, nodeName='phoneType', nodeType='STRING', nodeValue='work'} => Parent: Model{id=7, nodeName='arrayElement', nodeType='OBJECT'}
Model{id=9, nodeName='phoneNumber', nodeType='STRING', nodeValue='222-222-222'} => Parent: Model{id=7, nodeName='arrayElement', nodeType='OBJECT'}
Model{id=10, nodeName='taskIds', nodeType='ARRAY'} => Parent: Model{id=0, nodeName='ROOT', nodeType='null'}
Model{id=11, nodeName='arrayElement', nodeType='NUMBER', nodeValue='11'} => Parent: Model{id=10, nodeName='taskIds', nodeType='ARRAY'}
Model{id=12, nodeName='arrayElement', nodeType='NUMBER', nodeValue='22'} => Parent: Model{id=10, nodeName='taskIds', nodeType='ARRAY'}
Model{id=13, nodeName='arrayElement', nodeType='NUMBER', nodeValue='33'} => Parent: Model{id=10, nodeName='taskIds', nodeType='ARRAY'}
Model{id=14, nodeName='address', nodeType='OBJECT'} => Parent: Model{id=0, nodeName='ROOT', nodeType='null'}
Model{id=15, nodeName='street', nodeType='STRING', nodeValue='101 Blue Dr'} => Parent: Model{id=14, nodeName='address', nodeType='OBJECT'}
Model{id=16, nodeName='city', nodeType='STRING', nodeValue='White Smoke'} => Parent: Model{id=14, nodeName='address', nodeType='OBJECT'}
关于java - 使用 json 节点解析 JSon 字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59862363/
我正在编写一个具有以下签名的 Java 方法。 void Logger(Method method, Object[] args); 如果一个方法(例如 ABC() )调用此方法 Logger,它应该
我是 Java 新手。 我的问题是我的 Java 程序找不到我试图用作的图像文件一个 JButton。 (目前这段代码什么也没做,因为我只是得到了想要的外观第一的)。这是我的主课 代码: packag
好的,今天我在接受采访,我已经编写 Java 代码多年了。采访中说“Java 垃圾收集是一个棘手的问题,我有几个 friend 一直在努力弄清楚。你在这方面做得怎么样?”。她是想骗我吗?还是我的一生都
我的 friend 给了我一个谜语让我解开。它是这样的: There are 100 people. Each one of them, in his turn, does the following
如果我将使用 Java 5 代码的应用程序编译成字节码,生成的 .class 文件是否能够在 Java 1.4 下运行? 如果后者可以工作并且我正在尝试在我的 Java 1.4 应用程序中使用 Jav
有关于why Java doesn't support unsigned types的问题以及一些关于处理无符号类型的问题。我做了一些搜索,似乎 Scala 也不支持无符号数据类型。限制是Java和S
我只是想知道在一个 java 版本中生成的字节码是否可以在其他 java 版本上运行 最佳答案 通常,字节码无需修改即可在 较新 版本的 Java 上运行。它不会在旧版本上运行,除非您使用特殊参数 (
我有一个关于在命令提示符下执行 java 程序的基本问题。 在某些机器上我们需要指定 -cp 。 (类路径)同时执行java程序 (test为java文件名与.class文件存在于同一目录下) jav
我已经阅读 StackOverflow 有一段时间了,现在我才鼓起勇气提出问题。我今年 20 岁,目前在我的家乡(罗马尼亚克卢日-纳波卡)就读 IT 大学。足以介绍:D。 基本上,我有一家提供簿记应用
我有 public JSONObject parseXML(String xml) { JSONObject jsonObject = XML.toJSONObject(xml); r
我已经在 Java 中实现了带有动态类型的简单解释语言。不幸的是我遇到了以下问题。测试时如下代码: def main() { def ks = Map[[1, 2]].keySet()
一直提示输入 1 到 10 的数字 - 结果应将 st、rd、th 和 nd 添加到数字中。编写一个程序,提示用户输入 1 到 10 之间的任意整数,然后以序数形式显示该整数并附加后缀。 public
我有这个 DownloadFile.java 并按预期下载该文件: import java.io.*; import java.net.URL; public class DownloadFile {
我想在 GUI 上添加延迟。我放置了 2 个 for 循环,然后重新绘制了一个标签,但这 2 个 for 循环一个接一个地执行,并且标签被重新绘制到最后一个。 我能做什么? for(int i=0;
我正在对对象 Student 的列表项进行一些测试,但是我更喜欢在 java 类对象中创建硬编码列表,然后从那里提取数据,而不是连接到数据库并在结果集中选择记录。然而,自从我这样做以来已经很长时间了,
我知道对象创建分为三个部分: 声明 实例化 初始化 classA{} classB extends classA{} classA obj = new classB(1,1); 实例化 它必须使用
我有兴趣使用 GPRS 构建车辆跟踪系统。但是,我有一些问题要问以前做过此操作的人: GPRS 是最好的技术吗?人们意识到任何问题吗? 我计划使用 Java/Java EE - 有更好的技术吗? 如果
我可以通过递归方法反转数组,例如:数组={1,2,3,4,5} 数组结果={5,4,3,2,1}但我的结果是相同的数组,我不知道为什么,请帮助我。 public class Recursion { p
有这样的标准方式吗? 包括 Java源代码-测试代码- Ant 或 Maven联合单元持续集成(可能是巡航控制)ClearCase 版本控制工具部署到应用服务器 最后我希望有一个自动构建和集成环境。
我什至不知道这是否可能,我非常怀疑它是否可能,但如果可以,您能告诉我怎么做吗?我只是想知道如何从打印机打印一些文本。 有什么想法吗? 最佳答案 这里有更简单的事情。 import javax.swin
我是一名优秀的程序员,十分优秀!