当前位置:  编程技术>java/j2ee

地址到经纬度坐标转化的JAVA代码

    来源: 互联网  发布时间:2014-10-28

    本文导语:  任务:有1000多条门店信息(放在excel中,包括地址,店名,电话等,但是没有经纬度坐标),老大让我用地址通过百度地图拾取坐标系统找到相应的坐标,然后加上坐标后更新到公司的数据库。 失败的方案:1、使用按键精灵...

任务:有1000多条门店信息(放在excel中,包括地址,店名,电话等,但是没有经纬度坐标),老大让我用地址通过百度地图拾取坐标系统找到相应的坐标,然后加上坐标后更新到公司的数据库。

失败的方案:1、使用按键精灵,按键精灵是一个模仿键盘鼠标操作的软件,用来写动作脚本的,由于时间紧,没怎么研究,因为整套动作太复杂了按键精灵尝试了下不行就放弃了。

2、表单填充工具(就是把exel表格批量提交到网页),什么风越、乌溜漆(特别是这乌溜漆,还要钱,坑货)都尝试了下,结果都不满意。因为我要把excel中的内容提交到网页还要从网页获得相应的内容,所以这些用于批量注册的软件用不上。

解决方案:最后还是干起了我本行---写代码,把问题解决了。思路是:通过传入地址作为参数拼接url调用百度地图,然后解析返回的页面,提取经纬度坐标。

以下为具体步骤

1、修改excel表中的属性名(方便后面用查询读取)然后倒入到数据库。

2、代码实现

实体类

代码如下:

public class ShopInfo { 
    private String name; 
    private String scope; 
    private String address; 
    private String mobile;//手机  
    private String phone;//座机  
    private String description; 
    private String lat;//经度  
    private String lng;//纬度  

    public ShopInfo() { 

    } 
//....get和set方法 


关键代码  模拟http和解析返回的数据:

代码如下:

/*
 * 管理数据库连接的类
 */ 
public class DbManager{ 

    private Connection con = null ; 
    private Statement sta = null ; 
    private ResultSet rs = null ; 
    private PreparedStatement ps = null ; 

     
    private Connection cons = null ; 
    private Statement stas = null ; 
    private ResultSet rss = null ; 
    private PreparedStatement pss = null ; 

     

     
    //连接本地mysql参数 ?后面的参数是解决中文乱码的  
    private String MYSQLDRIVER="com.mysql.jdbc.Driver" ; 
    private String CONTENT="jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=utf8"; 
    private String UN="***"; 
    private String UP="****"; 

    //连接服务器mysql参数  
    private String MYSQLDRIVER1="com.mysql.jdbc.Driver" ; 
    private String CONTENT1="jdbc:mysql://***********:3306/test?useUnicode=true&characterEncoding=utf8"; 
    private String UN1="*******"; 
    private String UP1="****"; 

 
    public DbManager() 
    { 
        try { 

            Class.forName(MYSQLDRIVER); 
            System.out.println("加载MySQL驱动..."); 
            con = DriverManager.getConnection(CONTENT,UN,UP); 
            sta = con.createStatement(); 
            System.out.println("连接本地数据库成功!!"); 
            Class.forName(MYSQLDRIVER1); 
            System.out.println("加载MySQL驱动..."); 
            cons = DriverManager.getConnection(CONTENT1,UN1,UP1); 
            stas = cons.createStatement(); 
            System.out.println("连接服务器成功!!"); 

        } catch (Exception e) { 
            e.printStackTrace();     
        } 

    } 

 
    public ArrayList getAll(String tablename) throws SQLException{ 
        ArrayList allShops=new ArrayList(); 
        ShopInfo si; 

        String sql="select * from "+tablename; 
        System.out.println(sql); 
        rs=sta.executeQuery(sql); 
        while(rs.next()){ 
            si=new ShopInfo(); 
            si.setAddress(rs.getString("address")); 
            si.setDescription(rs.getString("names")+"欢迎您的光临"); 
            si.setMobile(rs.getString("keeperphone")); 
            si.setScope(tablename); 
            si.setPhone(rs.getString("shoptel")); 
            getPoint(si); 
            allShops.add(si); 
            System.out.println("经度:"+si.getLat()+"  纬度:"+si.getLng()); 
        } 

        return allShops; 
    } 
    //-------------------------》关键代码根据地址获得坐标《--------------------------------  
    public void getPoint(ShopInfo shop){ 
         try {   
                String sCurrentLine;   
                String sTotalString;   
                sCurrentLine = "";   
                sTotalString = "";   
                java.io.InputStream l_urlStream;   

                java.net.URL l_url = new java.net.URL("http://api.map.baidu.com/geocoder/v2/?address="+shop.getAddress().replaceAll(" ", "")+"&output=json&ak=702632E1add3d4953d0f105f27c294b9&callback=showLocation");   
                java.net.HttpURLConnection l_connection = (java.net.HttpURLConnection) l_url.openConnection();   
                l_connection.connect();   
                l_urlStream = l_connection.getInputStream();   
                java.io.BufferedReader l_reader = new java.io.BufferedReader(new java.io.InputStreamReader(l_urlStream));    
                String str=l_reader.readLine(); 
                //用经度分割返回的网页代码  
                String s=","+"""+"lat"+"""+":"; 
                String strs[]=str.split(s, 2); 
                String s1="""+"lng"+"""+":"; 
               String a[]=strs[0].split(s1, 2); 
               shop.setLng(a[1]); 
               s1="}"+","+"""; 
              String a1[]=strs[1].split(s1, 2); 
               shop.setLat(a1[0]); 
            } catch (Exception e) {   
                e.printStackTrace();   
            }   

    } 
    //存入数据库  
    public void inputAll(ArrayList allShops){ 
        System.out.println("开始向服务器中写入"); 
        String sql2="insert into test.dc_shop (name,scope,address,phone,description,image,createtime,lat,lng) values (?,?,?,?,?,?,?,?,?)"; 
        try { 
            pss=cons.prepareStatement(sql2); 
            System.out.println("-------------------------等待写入数据条数: "+allShops.size()); 
            for(int i=0;i

    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • libsvm 3.18基本介绍以及libsvm 3.18的官网地址及库下载地址
  • MAC地址是不是所谓的物理地址,他和IP地址通过什么来转换?
  • mongodb 下载官网地址
  • 知道IP地址,请问如何获取这个IP地址对应网卡的mac地址?
  • php通过socket_bind()设置IP地址代码示例
  • 平时用&取到的地址是虚拟地址还是真是的物理地址?
  • win7/Windows7系统下载地址搜集整理
  • 我有个ip地址,我不知道这个地址是哪里的?哪里有根据ip地址查所在地的软件可以下载啊?
  • Oracle 12c发布简单介绍及官方下载地址
  • 求教:关于内核物理地址和虚拟地址的问题
  • Hypertable 0.9.7.10 各种版本下载地址(最新版)
  • 《操作系统原理linux篇》逻辑地址,线性地址 物理地址
  • oracle 11g最新版官方下载地址
  • 虚拟地址→物理地址变换问题
  • PHP 5.4.19 和 PHP 5.5.3 发布及下载地址
  • Linux内存映射 物理地址映射到虚拟地址
  • Centos最新版6.4介绍及下载地址
  • linux内存管理虚拟地址 逻辑地址 交换分区(swp)
  • PF_RING 5.6.1(最新稳定版)下载地址
  • 用户进程有自己独立的地址空间,内核线程没有自己的地址空间 该怎样理解: ?
  • nginx最新主线开发版1.5.4发布及下载地址
  • 怎样获取物理内存在地址总线中的起始地址?




  • 特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3