CSV 到 JSON in JAVA (org.json) Headers 到键不起作用
CSV to JSON in JAVA (org.json) Headers to keys not working
这是我的 CSV 文件的内容:
FID,OBJECTID,SHAPE,LAGE,GRILLPLATZ_ID,RESERVIERUNG,WEBLINK1,SE_ANNO_CAD_DAT
"GRILLPLATZOGD.6748,6748,POINT (16.465255884594104 48.19018769574157),""22., Donauinsel, ca. 350 Meter stromab der Steinspornbrücke (Inselmitte, Erdwall)"",15,ja,http://www.wien.gv.at/amtshelfer/umwelt/wasserbau/donauinsel/grillplatzreservierung.html,"
"GRILLPLATZOGD.6749,6749,POINT (16.48177464603615 48.183356069714286),""22., Neue Donau, linkes Ufer, zwischen Steinspornbrücke und Waluliso Brücke (bei km 5,1) (Dammbereich) "",16,ja,http://www.wien.gv.at/amtshelfer/umwelt/wasserbau/donauinsel/grillplatzreservierung.html,"
"GRILLPLATZOGD.6750,6750,POINT (16.460158556964053 48.177745677669925),""11., Donaukanal, Alberner Hafenzufahrtsstraße, Nähe Margetinstraße"",0,nein,http://www.wien.gv.at/umwelt/wald/freizeit/grillen/,"
"GRILLPLATZOGD.6751,6751,POINT (16.22577870779843 48.20612009507929),""14., Auhof - Retentionsbecken"",0,nein,http://www.wien.gv.at/umwelt/wald/freizeit/grillen/,"
我的程序读取文件,然后使用 org.json 库生成一个 JSON 数组,其中填充了来自 CSV 的 JSONObject。
我程序的输出看起来像这样 atm:
[{"FID":"GRILLPLATZOGD.6748,6748,POINT (16.465255884594104 48.19018769574157),\"22., Donauinsel, ca. 350 Meter stromab der Steinspornbrücke (Inselmitte, Erdwall)\",15,ja,http://www.wien.gv.at/amtshelfer/umwelt/wasserbau/donauinsel/grillplatzreservierung.html,"} and so on...
我的问题是,CSV 中只有 header (FID) 的第一部分用于构建 JSON 密钥,header (OBJECTID,SHAPE,LAGE,GRILLPLATZ_ID,RESERVIERUNG,WEBLINK1,SE_ANNO_CAD_DAT) 被忽略。
这是我从 CSV 到 JSON 部分的代码片段。
import org.json.CDL;
import org.json.JSONArray;
import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
public class CSVReader {
public static void main(String[] args) {
String path = ""; //Insert path to CSV-File here
StringBuilder content = new StringBuilder();
String line;
String stringtoJSON;
try {
BufferedReader reader = new BufferedReader(new FileReader(path));
while ((line = reader.readLine()) != null) {
content.append(line);
content.append(System.lineSeparator());
}
stringtoJSON = content.toString();
System.out.println(stringtoJSON);
JSONArray jsonArray = CDL.toJSONArray(stringtoJSON);
System.out.println(jsonArray);
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
数组中的一个JSONObject应该是这样的:
{"FID": "GRILLPLATZOGD.6748", "OBJECTID": "6748", "SHAPE": "POINT (16.465255884594104 48.19018769574157)", "LAGE": "22., Donauinsel, ca. 350 Meter stromab der Steinspornbrücke (Inselmitte, Erdwall)","GRILLPLATZ_ID": "15","RESERVIERUNG": "ja","WEBLINK1":"http://www.wien.gv.at/amtshelfer/umwelt/wasserbau/donauinsel/grillplatzreservierung.html"}
在@Skilled_Teaser
的帮助下找到了解决方案
我把他的方法改成这样:
public static String removeUnnecessaryQuotes(String s){
String withoutQuotes;
withoutQuotes = s.substring(0).replaceAll("\"", "");
withoutQuotes.substring(0).replaceAll("\"\"", "\"");
return withoutQuotes;
}
现在它就像一个魅力。感谢您的帮助。
您的 CSV 文件可能有问题。试试下面这个。
FID,OBJECTID,SHAPE,LAGE,GRILLPLATZ_ID,RESERVIERUNG,WEBLINK1,SE_ANNO_CAD_DAT
"GRILLPLATZOGD.6748",6748,POINT (16.465255884594104 48.19018769574157),"22., Donauinsel, ca. 350 Meter stromab der Steinspornbrücke (Inselmitte, Erdwall)",15,ja,http://www.wien.gv.at/amtshelfer/umwelt/wasserbau/donauinsel/grillplatzreservierung.html
"GRILLPLATZOGD.6749",6749,POINT (16.48177464603615 48.183356069714286),"22., Neue Donau, linkes Ufer, zwischen Steinspornbrücke und Waluliso Brücke (bei km 5,1) (Dammbereich)",16,ja,http://www.wien.gv.at/amtshelfer/umwelt/wasserbau/donauinsel/grillplatzreservierung.html
"GRILLPLATZOGD.6750",6750,POINT (16.460158556964053 48.177745677669925),"11., Donaukanal, Alberner Hafenzufahrtsstraße, Nähe Margetinstraße",0,nein,http://www.wien.gv.at/umwelt/wald/freizeit/grillen/
"GRILLPLATZOGD.6751",6751,POINT (16.22577870779843 48.20612009507929),"14., Auhof - Retentionsbecken",0,nein,http://www.wien.gv.at/umwelt/wald/freizeit/grillen/
考虑更改 CSV 文件的结构,否则您将需要使用正则表达式将参数拆分为数组,然后创建 JSON.
编辑:
好的,我找到问题了。请添加以下方法并进行以下更改
while ((line = reader.readLine()) != null) {
content.append(line);
content.append(System.lineSeparator());
}
替换为:
while ((line = reader.readLine()) != null) {
content.append(removeUnnecessaryQuotes(line));
content.append(System.lineSeparator());
}
并添加方法:
public static String removeUnnecessaryQuotes(String s){
return s.substring(0, s.length() - 1).substring(1).replaceAll("\"\"", "\"");
}
这是我的 CSV 文件的内容:
FID,OBJECTID,SHAPE,LAGE,GRILLPLATZ_ID,RESERVIERUNG,WEBLINK1,SE_ANNO_CAD_DAT
"GRILLPLATZOGD.6748,6748,POINT (16.465255884594104 48.19018769574157),""22., Donauinsel, ca. 350 Meter stromab der Steinspornbrücke (Inselmitte, Erdwall)"",15,ja,http://www.wien.gv.at/amtshelfer/umwelt/wasserbau/donauinsel/grillplatzreservierung.html,"
"GRILLPLATZOGD.6749,6749,POINT (16.48177464603615 48.183356069714286),""22., Neue Donau, linkes Ufer, zwischen Steinspornbrücke und Waluliso Brücke (bei km 5,1) (Dammbereich) "",16,ja,http://www.wien.gv.at/amtshelfer/umwelt/wasserbau/donauinsel/grillplatzreservierung.html,"
"GRILLPLATZOGD.6750,6750,POINT (16.460158556964053 48.177745677669925),""11., Donaukanal, Alberner Hafenzufahrtsstraße, Nähe Margetinstraße"",0,nein,http://www.wien.gv.at/umwelt/wald/freizeit/grillen/,"
"GRILLPLATZOGD.6751,6751,POINT (16.22577870779843 48.20612009507929),""14., Auhof - Retentionsbecken"",0,nein,http://www.wien.gv.at/umwelt/wald/freizeit/grillen/,"
我的程序读取文件,然后使用 org.json 库生成一个 JSON 数组,其中填充了来自 CSV 的 JSONObject。
我程序的输出看起来像这样 atm:
[{"FID":"GRILLPLATZOGD.6748,6748,POINT (16.465255884594104 48.19018769574157),\"22., Donauinsel, ca. 350 Meter stromab der Steinspornbrücke (Inselmitte, Erdwall)\",15,ja,http://www.wien.gv.at/amtshelfer/umwelt/wasserbau/donauinsel/grillplatzreservierung.html,"} and so on...
我的问题是,CSV 中只有 header (FID) 的第一部分用于构建 JSON 密钥,header (OBJECTID,SHAPE,LAGE,GRILLPLATZ_ID,RESERVIERUNG,WEBLINK1,SE_ANNO_CAD_DAT) 被忽略。
这是我从 CSV 到 JSON 部分的代码片段。
import org.json.CDL;
import org.json.JSONArray;
import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
public class CSVReader {
public static void main(String[] args) {
String path = ""; //Insert path to CSV-File here
StringBuilder content = new StringBuilder();
String line;
String stringtoJSON;
try {
BufferedReader reader = new BufferedReader(new FileReader(path));
while ((line = reader.readLine()) != null) {
content.append(line);
content.append(System.lineSeparator());
}
stringtoJSON = content.toString();
System.out.println(stringtoJSON);
JSONArray jsonArray = CDL.toJSONArray(stringtoJSON);
System.out.println(jsonArray);
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
数组中的一个JSONObject应该是这样的:
{"FID": "GRILLPLATZOGD.6748", "OBJECTID": "6748", "SHAPE": "POINT (16.465255884594104 48.19018769574157)", "LAGE": "22., Donauinsel, ca. 350 Meter stromab der Steinspornbrücke (Inselmitte, Erdwall)","GRILLPLATZ_ID": "15","RESERVIERUNG": "ja","WEBLINK1":"http://www.wien.gv.at/amtshelfer/umwelt/wasserbau/donauinsel/grillplatzreservierung.html"}
在@Skilled_Teaser
的帮助下找到了解决方案我把他的方法改成这样:
public static String removeUnnecessaryQuotes(String s){
String withoutQuotes;
withoutQuotes = s.substring(0).replaceAll("\"", "");
withoutQuotes.substring(0).replaceAll("\"\"", "\"");
return withoutQuotes;
}
现在它就像一个魅力。感谢您的帮助。
您的 CSV 文件可能有问题。试试下面这个。
FID,OBJECTID,SHAPE,LAGE,GRILLPLATZ_ID,RESERVIERUNG,WEBLINK1,SE_ANNO_CAD_DAT
"GRILLPLATZOGD.6748",6748,POINT (16.465255884594104 48.19018769574157),"22., Donauinsel, ca. 350 Meter stromab der Steinspornbrücke (Inselmitte, Erdwall)",15,ja,http://www.wien.gv.at/amtshelfer/umwelt/wasserbau/donauinsel/grillplatzreservierung.html
"GRILLPLATZOGD.6749",6749,POINT (16.48177464603615 48.183356069714286),"22., Neue Donau, linkes Ufer, zwischen Steinspornbrücke und Waluliso Brücke (bei km 5,1) (Dammbereich)",16,ja,http://www.wien.gv.at/amtshelfer/umwelt/wasserbau/donauinsel/grillplatzreservierung.html
"GRILLPLATZOGD.6750",6750,POINT (16.460158556964053 48.177745677669925),"11., Donaukanal, Alberner Hafenzufahrtsstraße, Nähe Margetinstraße",0,nein,http://www.wien.gv.at/umwelt/wald/freizeit/grillen/
"GRILLPLATZOGD.6751",6751,POINT (16.22577870779843 48.20612009507929),"14., Auhof - Retentionsbecken",0,nein,http://www.wien.gv.at/umwelt/wald/freizeit/grillen/
考虑更改 CSV 文件的结构,否则您将需要使用正则表达式将参数拆分为数组,然后创建 JSON.
编辑:
好的,我找到问题了。请添加以下方法并进行以下更改
while ((line = reader.readLine()) != null) {
content.append(line);
content.append(System.lineSeparator());
}
替换为:
while ((line = reader.readLine()) != null) {
content.append(removeUnnecessaryQuotes(line));
content.append(System.lineSeparator());
}
并添加方法:
public static String removeUnnecessaryQuotes(String s){
return s.substring(0, s.length() - 1).substring(1).replaceAll("\"\"", "\"");
}