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

任务:有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<ShopInfo> getAll(String tablename) throws SQLException{ 
        ArrayList<ShopInfo> 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<ShopInfo> 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<allShops.size();i++){ 
                   pss.setString(1,allShops.get(i).getName()); 
                pss.setString(2, allShops.get(i).getScope()); 
                pss.setString(3, allShops.get(i).getAddress()); 
                pss.setString(4, allShops.get(i).getPhone()); 
                pss.setString(5, allShops.get(i).getDescription()); 
                pss.setString(6, null);//图片路径  
                pss.setString(7, allShops.get(i).getMobile()); 
                pss.setString(8, allShops.get(i).getLat()); 
                pss.setString(9, allShops.get(i).getLng()); 

                pss.executeUpdate(); 
            } 
            pss.close(); 
            cons.close(); 

            System.out.println("--->OK"); 
        } catch (SQLException e) { 
            // TODO Auto-generated catch block  
            System.out.println("向mysql中更新数据时发生异常!"); 
            e.printStackTrace();     
        } 
    } 

在搞个main函数调用就ok了。

时间: 2024-12-20 22:55:16

地址到经纬度坐标转化的JAVA代码_java的相关文章

微信APP支付Java代码_java

本文实例为大家分享了java微信APP支付代码,供大家参考,具体内容如下 import java.io.IOException; import java.io.UnsupportedEncodingException; import java.util.Random; import org.apache.http.ParseException; import org.apache.http.client.ClientProtocolException; import org.apache.htt

MAC 系统如何使用 Sublime Text 2 直接编译运行 java 代码_java

修改 /Users/$username/Library/Application Support/Sublime Text 2/Packages/Java/JavaC.sublime-build 为: 复制代码 代码如下: {  "cmd": ["java", "$file_base_name"],  "file_regex": "^ *\\[javac\\] (.+):([0-9]+):() (.*)$",

日历显示读出输入的年月的java代码_java

复制代码 代码如下: import java.awt.*;import java.awt.event.*;import java.util.Calendar; import javax.swing.JOptionPane; class CalendarBean {  //定义一个日历类 String day[]; //天数数组 int year = 2011, month = 9; //给定一个初始年月  public void setYear(int year) {   this.year =

从字符串中截取等长字节的Java代码_java

在页面显示的时候,有时候文字无法显示完全,就只能显示部分文字,但是直接截取就只能截取等长字符串,英文和中文很难处理所以就写了下面方法,截取等长字符 复制代码 代码如下: public static void main(String[] args) {   String str = "20120131:<回家>1你好么" ;   System.out.println( subString(str , 10 ) ) ;  } public static String subSt

Winform下的地图开发控件(GMap.NET)使用心得之三---批量解析地址经纬度坐标

在之前的文章中,介绍了两篇关于GMap.NET这样的开源地图控件,介绍了其一些基本信息以及如何进行初步的应用. Winform下的地图开发控件(GMap.NET)使用心得 Winform下的地图开发控件(GMap.NET)使用心得之二 这是一个基于Winform的地图控件.该地图控件的定义如下: GMap.NET是一个强大.免费.跨平台.开源的.NET控件,它在Windows Forms 和WPF环境中能够通过Google, Yahoo!, Bing, OpenStreetMap, ArcGIS

Java将GeoHash转化为对应的经纬度坐标实例代码_java

本文实例介绍了JAVA实现将GeoHash转化为对应的经纬度坐标的详细代码,分享给大家供大家参考,具体内容如下 package com.lulei.geo; import java.util.ArrayList; import java.util.Arrays; import java.util.HashMap; import java.util.List; import com.lulei.geo.bean.LocationBean; import com.lulei.util.JsonUti

wgp-急求将GPS测得的经纬度(WGS84)转换成xy坐标的java代码

问题描述 急求将GPS测得的经纬度(WGS84)转换成xy坐标的java代码 急求将GPS测得的经纬度(WGS84)转换成xy坐标的java代码 解决方案 经纬度其实就是XY坐标 只是不知你说的XY坐标指的是什么? 百度地图?google地图? 不同地图坐标有差别 再说也不用转换,直接给经纬度就行了 //Double latitude = 22.560034 * 1E6;

java代码 如何将图片转化成矩阵数组的形式! 跪求~~

问题描述 java代码 如何将图片转化成矩阵数组的形式! 跪求-- java代码 如何将图片转化成矩阵数组的形式! 跪求-- 像素数据和二进制数据都可以! java代码 如何提取函数图像的数据,最大值,最小值,变化趋势等等... 请教各位大神们!! 解决方案 http://stchou.iteye.com/blog/819191 参考这个代码,可以读取每个像素的颜色,之后你想怎么处理就怎么处理

关于希尔伯特曲线与二维坐标 java代码实现

问题描述 关于希尔伯特曲线与二维坐标 java代码实现 不知道有没有人有这样的java源码,就是输入希尔伯特曲线的阶数,能返回一个希尔伯特曲线每个编号所在的x.y的二维坐标,当然这个坐标是一个数据集.或者输入希尔伯特曲线的阶数和编号,得到一个二维坐标.希望大神有源码,这个我实在很难自己想出来.谢谢大家了! 解决方案 有人知道么????? 解决方案二: 有人知道么????? 解决方案三: 想问下,你解决了吗?