-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathEarthQuakeParser.java
102 lines (97 loc) · 4.38 KB
/
EarthQuakeParser.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
import java.io.File;
import java.io.IOException;
import java.util.*;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import org.w3c.dom.*;
import org.xml.sax.SAXException;
public class EarthQuakeParser {
public EarthQuakeParser() {
// TODO Auto-generated constructor stub
}
public ArrayList<QuakeEntry> read(String source) {
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
try {
DocumentBuilder builder = factory.newDocumentBuilder();
//Document document = builder.parse(new File(source));
//Document document = builder.parse("http://earthquake.usgs.gov/earthquakes/feed/v1.0/summary/2.5_week.atom");
Document document = null;
if (source.startsWith("http")){
document = builder.parse(source);
}
else {
document = builder.parse(new File(source));
}
//Document document = builder.parse("http://earthquake.usgs.gov/earthquakes/feed/v1.0/summary/all_week.atom");
NodeList nodeList = document.getDocumentElement().getChildNodes();
ArrayList<QuakeEntry> list = new ArrayList<QuakeEntry>();
for(int k=0; k < nodeList.getLength(); k++){
Node node = nodeList.item(k);
if (node.getNodeName().equals("entry")) {
Element elem = (Element) node;
NodeList t1 = elem.getElementsByTagName("georss:point");
NodeList t2 = elem.getElementsByTagName("title");
NodeList t3 = elem.getElementsByTagName("georss:elev");
double lat = 0.0, lon = 0.0, depth = 0.0;
String title = "NO INFORMATION";
double mag = 0.0;
if (t1 != null) {
String s2 = t1.item(0).getChildNodes().item(0).getNodeValue();
//System.out.print("point2: "+s2);
String[] args = s2.split(" ");
lat = Double.parseDouble(args[0]);
lon = Double.parseDouble(args[1]);
}
if (t2 != null){
String s2 = t2.item(0).getChildNodes().item(0).getNodeValue();
String mags = s2.substring(2,s2.indexOf(" ",2));
if (mags.contains("?")) {
mag = 0.0;
System.err.println("unknown magnitude in data");
}
else {
mag = Double.parseDouble(mags);
//System.out.println("mag= "+mag);
}
int sp = s2.indexOf(" ",5);
title = s2.substring(sp+1);
if (title.startsWith("-")){
int pos = title.indexOf(" ");
title = title.substring(pos+1);
}
}
if (t3 != null){
String s2 = t3.item(0).getChildNodes().item(0).getNodeValue();
depth = Double.parseDouble(s2);
}
QuakeEntry loc = new QuakeEntry(lat,lon,mag,title,depth);
list.add(loc);
}
}
return list;
}
catch (ParserConfigurationException pce){
System.err.println("parser configuration exception");
}
catch (SAXException se){
System.err.println("sax exception");
}
catch (IOException ioe){
System.err.println("ioexception");
}
return null;
}
public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException{
EarthQuakeParser xp = new EarthQuakeParser();
//String source = "data/2.5_week.atom";
//String source = "http://earthquake.usgs.gov/earthquakes/feed/v1.0/summary/all_week.atom";
String source = "E:/Coursera/nov20quakedata.atom";
ArrayList<QuakeEntry> list = xp.read(source);
Collections.sort(list);
for(QuakeEntry loc : list){
System.out.println(loc);
}
System.out.println("# quakes = "+list.size());
}
}