这是我在这里发表的第一篇文章,希望有人可以帮助我,因为我无法理解错误。
我有一个解析JSON字符串的java方法
public static String getFieldFrom(String field, String event) {
try {
JsonElement jelement = new JsonParser().parse(event);
JsonObject obj = jelement.getAsJsonObject();
return obj.getAsJsonObject("from").get(field).getAsString();
}catch(Exception e) {
System.out.println("Error parsing field " + field + ": " + e);
}
return "-1";
}
事件是字符串,并且字段是我感兴趣的字段。在eclipse上运行时程序运行正常。如果我把它编译为一个罐子,我尝试运行它,我得到一个异常:
com.google.gson.JsonSyntaxException: com.google.gson.stream.MalformedJsonException: Use JsonReader.setLenient(true) to accept malformed JSON at line 1 column 3 path $
正在处理的JSON字符串是相同的,这个(看起来对我有效):
{"event": "message", "id": "00000000b0a2a54e1a01000000000000d", "flags": 258, "fwd_from": {"id": "$01000000428d8006442ef91f3ed48e27", "peer_type": "user", "peer_id": 109088066, "print_name": "Sample_Name", "flags": 1, "first_name": "Name", "last_name": "Sample", "username": "sampleuser"}, "fwd_date": 1522850949, "from": {"id": "$050023200b0a234e82865474b11fd9cd", "peer_type": "channel", "peer_id": 123232323, "print_name": "ChnNameTest", "flags": 19609, "title": "ChnNameTest", "participants_count": 0, "admins_count": 0, "kicked_count": 0}, "to": {"id": "$011200000b0a2a54e812345674b47fd9cd", "peer_type": "channel", "peer_id": 1319412121236, "print_name": "ChnNameTest", "flags": 196609, "title": "ChnNameTest", "participants_count": 0, "admins_count": 0, "kicked_count": 0}, "out": true, "unread": false, "service": false, "date": 1522850949, "text": "This is the message text"}
我试图获得" id"领域,"来自"宾语。我也尝试过另一个库(org.json),但行为是一样的。再说一遍,如果我在eclipse上运行代码它就可以工作了。 我真的不知道该尝试什么...希望有人可以帮助我! 谢谢!
更新 问题似乎与传递的字符串有关。所以这是一段代码,它读取我调用的脚本的stdout(发回json文本)。
Process child = Runtime.getRuntime().exec(command);
InputStream in = child.getInputStream();
int c;
char ca;
String line="";
while ((c = in.read()) != -1) { //Read stdout char by char
ca=(char)c;
if(ca=='\n' || ca=='\r') { //Got a line
if(line.contains("{\"event\":")) {
System.out.println(getFieldFrom("id",line)));
}
line="";
}else {
line=line+ca;
}
}
in.close();
答案 0 :(得分:0)
这对我有用。
String json="{\"event\": \"message\", \"id\": \"00000000b0a2a54e1a01000000000000d\", \"flags\": 258, \"fwd_from\": {\"id\": \"$01000000428d8006442ef91f3ed48e27\", \"peer_type\": \"user\", \"peer_id\": 109088066, \"print_name\": \"Sample_Name\", \"flags\": 1, \"first_name\": \"Name\", \"last_name\": \"Sample\", \"username\": \"sampleuser\"}, \"fwd_date\": 1522850949, \"from\": {\"id\": \"$050023200b0a234e82865474b11fd9cd\", \"peer_type\": \"channel\", \"peer_id\": 123232323, \"print_name\": \"ChnNameTest\", \"flags\": 19609, \"title\": \"ChnNameTest\", \"participants_count\": 0, \"admins_count\": 0, \"kicked_count\": 0}, \"to\": {\"id\": \"$011200000b0a2a54e812345674b47fd9cd\", \"peer_type\": \"channel\", \"peer_id\": 1319412121236, \"print_name\": \"ChnNameTest\", \"flags\": 196609, \"title\": \"ChnNameTest\", \"participants_count\": 0, \"admins_count\": 0, \"kicked_count\": 0}, \"out\": true, \"unread\": false, \"service\": false, \"date\": 1522850949, \"text\": \"This is the message text\"}";
Gson gson = new Gson();
JsonObject obj = gson.fromJson(json, JsonElement.class).getAsJsonObject();
String str = obj.getAsJsonObject("from").get("id").getAsString();
System.out.println(str);
输出:
$050023200b0a234e82865474b11fd9cd
答案 1 :(得分:0)
谢谢@Nephilim!
通过以下方式解决:
event.trim();
在from datetime import datetime
time = datetime.now()
print(time)
之后,字符串的开头有一个“[K”,之前是不可见的。删除后“[K”一切正常!
这可能是一些修饰“扩展”的隐藏的焦点。