3

我得到了这样的彭博回应。我想解析这个并将值放入 excel 或 csv 中。

Bloomberg 响应是一种 XML 响应中令人头疼的问题。有没有直接解析成 JSON 的简单方法?(来自对象“会话”或来自对象“事件”)

HistoricalDataResponse = {
    securityData = {
        security = "S X5 Comdty"
        eidData[] = {
            14001, 14001
        }
        sequenceNumber = 1
        fieldExceptions[] = {
        }
        fieldData[] = {
            fieldData = {
                date = 2015-05-06
                PX_LAST = 956.0
                OPEN = 967.25
            }
            fieldData = {
                date = 2015-06-06
                PX_LAST = 914.25
                OPEN = 956.0
            }
        }
    }
}

这是回应。由于我们在任何 json 在线查看器中都有“=”而不是“:”,因此它会将错误视为无效的 json。

4

1 回答 1

3

Bloomberg API 不会生成有效的 JSON。尽管您可能会在进行一些修改后将其解析为 JSON,但它不是一种可靠的方法,因为格式可能会根据您要检索的查询类型和字段而有所不同(并且将来可能会发生变化,因为它不属于规范)。

您应该使用文档中详述的方法对其进行解析(参见开发人员指南的第 7.2.2 节 - 历史数据请求中的示例)。

或者,您可以使用jBloomberg(免责声明:我是作者),您的代码如下所示:

 BloombergSession session = new DefaultBloombergSession();
 LocalDate now = LocalDate.now();
 RequestBuilder<HistoricalData> hrb = new HistoricalRequestBuilder("S X5 Comdty",
                          Arrays.asList("PX_LAST", "OPEN"),
                          now.minusDays(7), now);

 HistoricalData result = session.submit(hrb).get();
 Map<LocalDate, TypedObject> data = result.forSecurity("SPX Index").forField("PX_LAST").get();
 for (Map.Entry<LocalDate, TypedObject> e : data.entrySet()) {
     LocalDate dt = e.getKey();
     double price = e.getValue().asDouble();
     System.out.println("[" + dt + "] " + price);
 }

本页底部提供了更多示例。

于 2015-06-09T08:59:20.210 回答