// 汇率解读:
// skip(Constant.RATE_START):跳过列表中的前 Constant.RATE_START 个元素。
// limit(Constant.RATE_END - Constant.RATE_START):限制处理的元素数量为 Constant.RATE_END - Constant.RATE_START。
// filter(rate -> rate != null && rate.compareTo(BigDecimal.ZERO) != 0):过滤掉 null 和等于 BigDecimal.ZERO 的元素。
// findFirst():获取符合条件的第一个元素。
// orElse(BigDecimal.ZERO):如果没有符合条件的元素,则返回 BigDecimal.ZERO
public static void main(String[] args) {
String jsonString =
“[{“currency_name”: “USD”, “release_date”:” + " “2023-10-01”, " +
““现汇买入”: 10150, “现钞买入”: 9975,” +
" “现汇卖出”: ‘’, “现钞卖出”: ‘’," +
" “中行折算”: ‘30050’}]";
JSONArray result = JSON.parseArray(jsonString);for (Object res : result) {JSONObject orderObj = (JSONObject) res;String currencyName = orderObj.getString("currency_name");String releaseDate = orderObj.getString("release_date");List<BigDecimal> rateList = new ArrayList<>();List<String> keys = Arrays.asList("现汇买入", "现钞买入","现汇卖出", "现钞卖出", "中行折算");Arrays.asList("现汇买入", "现钞买入", "现汇卖出", "现钞卖出", "中行折算").forEach(key -> {BigDecimal rate = orderObj.getBigDecimal(key);if (rate != null) {rate = rate.divide(new BigDecimal(100));}rateList.add(rate);});BigDecimal rateCurrent = rateList.stream().skip(Constant.RATE_START).limit(Constant.RATE_END - Constant.RATE_START).filter(rate -> rate != null && rate.compareTo(BigDecimal.ZERO) != 0).findFirst().orElse(BigDecimal.ZERO);System.out.println(rateCurrent);}
}