GPS坐标转换成百度坐标-如何解析json返回值

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: GPS坐标转换成百度坐标-如何解析json返回值

一、背景


      公司碰到了一个数据迁移业务,就是把客户平台的GPS坐标迁移到自己平台,自己平台使用的是百度坐标,这就需要转换了,我是将客户公司的gps经纬度字段以及主键id导出为csv文件,这个csv文件每行三个字段,写一个脚本读取csv文件,根据每行拿到的GPS经纬度请求百度坐标转换接口,获取返回的百度经纬度,生成一个每行五个字段的csv文件,即(id,GPS经度,GPS纬度,百度经度,百度纬度)五个字段,将生成的csv文件导入自己平台数据库生成临时文件,写sql刷新自己的数据的百度经纬度字段。


二、主要实现


1、访问 http://lbsyun.baidu.com/index.php?title=webapi/guide/changeposition 查看百度如何进行转换,接口如下。由api接口可知,我们读取csv中的GPS经纬度替换coords参数,from的参数我用的是1,代表WGS84坐标,使用其他的坐标请查看百度api,to的参数我用的是5,表示要转换为百度经纬度坐标,ak需要自己去百度申请。

http://api.map.baidu.com/geoconv/v1/?coords=114.21892734521,29.575429778924&from=1&to=5&ak=你的密钥

2、读取每一行原始csv文件时,我们就请求坐标转换接口,返回百度经纬度坐标,组成包括(id,GPS经度,GPS纬度,百度经度,百度纬度)五个字段的bean加入到集合中,方便后续写入新的csv文件。方法如下:


(1)方法参数datas为转换后的数据集合


(2)goalPath为原始的只有GPS坐标的csv文件

    public static void readCSV(List<ResultBean> datas, String goalPath) {
        try (CSVReader csvReader = new CSVReaderBuilder(new BufferedReader(new InputStreamReader(new FileInputStream(new File(goalPath)), "utf-8"))).build()) {
            Iterator<String[]> iterator = csvReader.iterator();
            iterator.next();
            while (iterator.hasNext()) {
                String[] next = iterator.next();
                if (next[1] == null || "".equals(next[1]) || next[2] == null || "".equals(next[2])) {
                    ResultBean bean = new ResultBean(next[0], next[1], next[2], null, null);
                    datas.add(bean);
                } else {
                    String address = m.format(new Object[]{next[1], next[2]});
                    ResponseEntity<BaiDuReturnBean> result = restTemplate.getForEntity(address, BaiDuReturnBean.class);
                    if ("0".equals(result.getBody().getStatus())) {
                        Object x = result.getBody().getResult().get(0).get("x");
                        Object y = result.getBody().getResult().get(0).get("y");
                        ResultBean bean = new ResultBean(next[0], next[1], next[2], String.valueOf(x), String.valueOf(y));
                        datas.add(bean);
                    } else {
                        ResultBean bean = new ResultBean(next[0], next[1], next[2], null, null);
                        datas.add(bean);
                    }
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

3、该ResultBean就是封装的集合中的bean  代码如下:包含(id,GPS经度,GPS纬度,百度经度,百度纬度)五个字段,见注释。

 static class ResultBean {
        //客户主键id
        private String external_id;
        //GPS经纬度
        private String v_longitude;
        private String v_latitude;
        //百度经纬度
        private String longitude;
        private String latitude;
        public ResultBean(String external_id, String v_longitude, String v_latitude, String longitude, String latitude) {
            this.external_id = external_id;
            this.v_longitude = v_longitude;
            this.v_latitude = v_latitude;
            this.longitude = longitude;
            this.latitude = latitude;
        }
        public String getExternal_id() {
            return external_id;
        }
        public String getV_longitude() {
            return v_longitude;
        }
        public String getV_latitude() {
            return v_latitude;
        }
        public String getLongitude() {
            return longitude;
        }
        public String getLatitude() {
            return latitude;
        }
    }

4、上面方法中,有两个变量是全局变量,如下

(1)m为百度请求的接口模板,上面方法对模板中的经纬度进行了替换

(2) restTemplate来发送get请求百度坐标转换接口

    private static MessageFormat m = new MessageFormat("http://api.map.baidu.com/geoconv/v1/?coords={0},{1}&from=1&to=5&ak=60LLHS");
    private static RestTemplate restTemplate = new RestTemplate();

5、BaiDuReturnBean是对请求百度接口返回值进行解析,

(1)请求百度接口返回为json格式,如下

{
    "status": 0,
    "result": [
        {
            "x": 114.2307519546763,
            "y": 29.57908428837437
        }
    ]
}

根据返回值可知,返回status的字符串,和result的list下面是包含x和y的map,所以需要以下格式的bean进行解析

    static class BaiDuReturnBean {
        String status;
        List<Map<String, Object>> result;
        public String getStatus() {
            return status;
        }
        public void setStatus(String status) {
            this.status = status;
        }
        public List<Map<String, Object>> getResult() {
            return result;
        }
        public void setResult(List<Map<String, Object>> result) {
            this.result = result;
        }
    }

6、除了通过新建符合条件的bean解析json返回值,我们也可以用下面的方式进行解析。通过JacksonJsonParser进行解析

        RestTemplate restTemplate = new RestTemplate();
        String address = "http://api.map.baidu.com/geoconv/v1/?coords=114.21892734521,29.575429778924&from=1&to=5&ak=QqHS";
        ResponseEntity result = restTemplate.getForEntity(address, String.class);
        String body = (String) result.getBody();
        Map<String, Object> map = new JacksonJsonParser().parseMap(body);
        System.out.println(map.get("status"));
        List<Map> result1 = (List) map.get("result");
        Object x = result1.get(0).get("x");
        System.out.println(x);

7、最后我们通过调用写方法将转换后的bean集合写入新的csv中

(1)datas为转换后的坐标集合

(2)sourcePath为要生成的csv文件路径

    public static void writeCSV(List<ResultBean> datas, String sourcePath) {
        CsvWriter csvWriter = new CsvWriter(new File(sourcePath));
        for (ResultBean data : datas) {
            csvWriter.write(new String[]{data.getExternal_id(), data.getV_longitude(), data.getV_latitude(), data.getLongitude(), data.getLatitude()});
        }
        csvWriter.close();
    }

三、总结

以上就是关于GPS坐标转换为百度坐标的示例,要是觉得调用一次百度接口转换一个速度慢,可以一次最多转换100个,多组坐标以“;”分隔。希望能够对你的思路有帮助。公号java基础笔记,有需要可以关注。

目录
相关文章
|
2月前
|
SQL 存储 JSON
SQL,解析 json
SQL,解析 json
80 8
|
10天前
|
数据采集 JSON API
如何利用Python爬虫淘宝商品详情高级版(item_get_pro)API接口及返回值解析说明
本文介绍了如何利用Python爬虫技术调用淘宝商品详情高级版API接口(item_get_pro),获取商品的详细信息,包括标题、价格、销量等。文章涵盖了环境准备、API权限申请、请求构建和返回值解析等内容,强调了数据获取的合规性和安全性。
|
3月前
|
存储 前端开发 JavaScript
前端基础(十二)_函数高级、全局变量和局部变量、 预解析(变量提升)、函数返回值
本文介绍了JavaScript中作用域的概念,包括全局变量和局部变量的区别,预解析机制(变量提升),以及函数返回值的使用和类型。通过具体示例讲解了变量的作用域、函数的返回值、以及如何通过return关键字从函数中返回数据。
25 1
前端基础(十二)_函数高级、全局变量和局部变量、 预解析(变量提升)、函数返回值
|
4月前
|
存储 JSON API
淘系API接口(解析返回的json数据)商品详情数据解析助力开发者
——在成长的路上,我们都是同行者。这篇关于商品详情API接口的文章,希望能帮助到您。期待与您继续分享更多API接口的知识,请记得关注Anzexi58哦! 淘宝API接口(如淘宝开放平台提供的API)允许开发者获取淘宝商品的各种信息,包括商品详情。然而,需要注意的是,直接访问淘宝的商品数据API通常需要商家身份或开发者权限,并且需要遵循淘宝的API使用协议。
淘系API接口(解析返回的json数据)商品详情数据解析助力开发者
|
3月前
|
JSON API 数据格式
requests库中json参数与data参数使用方法的深入解析
选择 `data`或 `json`取决于你的具体需求,以及服务器端期望接收的数据格式。
303 2
|
3月前
|
JSON 前端开发 JavaScript
解析JSON文件
解析JSON文件
152 9
|
2月前
|
JSON JavaScript API
商品详情数据接口解析返回的JSON数据(API接口整套流程)
商品详情数据接口解析返回的JSON数据是API接口使用中的一个重要环节,它涉及从发送请求到接收并处理响应的整个流程。以下是一个完整的API接口使用流程,包括如何解析返回的JSON数据:
|
3月前
|
存储 JSON API
Python编程:解析HTTP请求返回的JSON数据
使用Python处理HTTP请求和解析JSON数据既直接又高效。`requests`库的简洁性和强大功能使得发送请求、接收和解析响应变得异常简单。以上步骤和示例提供了一个基础的框架,可以根据你的具体需求进行调整和扩展。通过合适的异常处理,你的代码将更加健壮和可靠,为用户提供更加流畅的体验。
211 0
|
1月前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
77 2
|
3天前
|
存储 设计模式 算法
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析
行为型模式用于描述程序在运行时复杂的流程控制,即描述多个类或对象之间怎样相互协作共同完成单个对象都无法单独完成的任务,它涉及算法与对象间职责的分配。行为型模式分为类行为模式和对象行为模式,前者采用继承机制来在类间分派行为,后者采用组合或聚合在对象间分配行为。由于组合关系或聚合关系比继承关系耦合度低,满足“合成复用原则”,所以对象行为模式比类行为模式具有更大的灵活性。 行为型模式分为: • 模板方法模式 • 策略模式 • 命令模式 • 职责链模式 • 状态模式 • 观察者模式 • 中介者模式 • 迭代器模式 • 访问者模式 • 备忘录模式 • 解释器模式
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析

热门文章

最新文章

推荐镜像

更多