我想使用来自使用YQL生成的XML响应中的信息来获取库存历史数据,例如此链接
http://query.yahooapis.com/v1/public/yql?q=select%20*%20from%20yahoo.finance.historicaldata%20where%20symbol%20in%20(%22MSFT%22)%20and%20startDate%3D%222011-2-12%22%20and%20endDate%3D%222011-2-15%22%0A%09%09&diagnostics=true&env=http%3A%2F%2Fdatatables.org%2Falltables.env
并将其存储到库存对象数组中。我是Java的新手,我不了解它的XML api。我不知道这样做的简单方法是什么。有人可以建议我一个好的解决方案。感谢。
答案 0 :(得分:4)
您可以使用JAXB(JSR-222)实现执行以下操作:
<强>演示强>
import java.io.InputStream;
import java.net.URL;
import javax.xml.bind.JAXBContext;
import javax.xml.bind.Marshaller;
import javax.xml.bind.Unmarshaller;
public class Demo {
public static void main(String[] args) throws Exception {
JAXBContext jc = JAXBContext.newInstance(Stock.class);
Unmarshaller unmarshaller = jc.createUnmarshaller();
URL url = new URL("http://query.yahooapis.com/v1/public/yql?q=select%20*%20from%20yahoo.finance.historicaldata%20where%20symbol%20in%20(%22MSFT%22)%20and%20startDate%3D%222011-2-12%22%20and%20endDate%3D%222011-2-15%22%0A%09%09&diagnostics=true&env=http%3A%2F%2Fdatatables.org%2Falltables.env");
InputStream xmlStream = url.openStream();
Stock stock = (Stock) unmarshaller.unmarshal(xmlStream);
Marshaller marshaller = jc.createMarshaller();
marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
marshaller.marshal(stock, System.out);
}
}
<强>库存强>
import java.util.List;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlElementWrapper;
import javax.xml.bind.annotation.XmlRootElement;
@XmlRootElement(name="query")
@XmlAccessorType(XmlAccessType.FIELD)
public class Stock {
@XmlElementWrapper(name="results")
@XmlElement(name="quote")
private List<Quote> quotes;
}
<强>引用强>
import java.util.Date;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlSchemaType;
@XmlAccessorType(XmlAccessType.FIELD)
public class Quote {
@XmlElement(name="Date")
@XmlSchemaType(name="date")
private Date date;
@XmlElement(name="Open")
private double open;
@XmlElement(name="High")
private double high;
@XmlElement(name="Low")
private double low;
@XmlElement(name="Close")
private double close;
@XmlElement(name="Volume")
private long volume;
@XmlElement(name="Adj_Close")
private double adjClose;
}