本案例由于google每天每个账户能post20000次所以我们需要相对较长的时间来抓去google的数据信息。

主要思路:通过一定的zoom一个相对较大的zoom。我们尽可能的搜索我们的所有数据。 之后我们获取google的搜索数据如下图

我们要抓去的就是上面的小红点了。 我这边抓去全国的小区信息用一台服务器跑了20天左右将全国的小区信息基本上都抓到了。 小到县 镇 的小区信息也抓到了。 相对还是比较理想。当时分析消耗了大量的时间。 由于我需要获取这个小区名称以及地图的坐标点所以这块还是有一定的分析的技术含量的。

抓去的数据不是只有 一个页面我们需要post分页抓去。这点需要注意。代码当时只是比较简单的处理。 注重的是过程就不上传了。 给大家提供一些思路。

我们需要定义2个非常主要的google的url这两个是我们获取地址信息以及经纬度信息的关键点。

private string areaStr = "http://mt0.google.com/vt/pt?lyrs=m%40215000000&las={0}%3B{1}%3B{2}%3B{3}&z=14&ptv=1";
private string areaInfoStr = "http://mt0.google.com/vt/ft?lyrs=lmq:1000:%E5%B0%8F%E5%8C%BA|cc:CN|h:a|s:109146043351405611748|xc:14&las={0}&z=15&gl=cn&hl=zh-CN&xc=1";

程序的主要思路是将整个中国的范围包含在我们设置的区域里。 之后就程序自动拖动获取小区信息。 在抓去详细信息。

private void GetAraeInfo(string araeCode)
{
int zoom = ;
var objPar = new object[];
objPar[] = this.currentPointF.X;
objPar[] = this.currentPointF.Y;
objPar[] = zoom;
wbGoogle.Document.InvokeScript("SetCenter", objPar);
var latlngArr = wbGoogle.Document.InvokeScript("GetBounds").ToString().Split(',');
this.subX = double.Parse(latlngArr[]) - double.Parse(latlngArr[]);
this.subY = double.Parse(latlngArr[]) - double.Parse(latlngArr[]);
string url = string.Format(areaStr, latlngArr[], latlngArr[], latlngArr[], latlngArr[]);
GetInfo(url, araeCode);
bool flag = false;
while (true)
{
if (this.currentPointF.X > this.rightBottomPointF.X)
{
this.currentPointF.X = this.currentPointF.X - this.subX;
}
else
{
if (flag)
{
break;
}
this.currentPointF.Y = this.currentPointF.Y + this.subY;
this.currentPointF.X = this.leftTopPointF.X;
if (this.currentPointF.Y > this.rightBottomPointF.Y)
{
flag = true;
}
}
//地图设置中心点
objPar[] = this.currentPointF.X;
objPar[] = this.currentPointF.Y;
objPar[] = zoom;
Console.WriteLine("X:" + this.currentPointF.X + " Y:" + this.currentPointF.Y);
wbGoogle.Document.InvokeScript("SetCenter", objPar);
latlngArr = wbGoogle.Document.InvokeScript("GetBounds").ToString().Split(',');
url = string.Format(areaStr, latlngArr[], latlngArr[], latlngArr[], latlngArr[]);
GetInfo(url, araeCode);
Thread.Sleep();
Application.DoEvents();
}
}

获取html数据信息当然也是少不了的。

public static String GetHtml(string url)
{
try
{ HttpWebRequest req = HttpWebRequest.Create(url) as HttpWebRequest;
req.Timeout = * ;
req.Method = "get";
req.ContentType = "application/x-www-form-urlencoded";
req.Accept = "*/*";
req.Headers.Add(HttpRequestHeader.AcceptLanguage, "zh-CN");
req.UserAgent = "Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; Trident/4.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; .NET4.0C; .NET4.0E)";
HttpWebResponse response = req.GetResponse() as HttpWebResponse;
Stream stream = response.GetResponseStream();
MemoryStream buffer = new MemoryStream();
Byte[] temp = new Byte[];
int count = ;
while ((count = stream.Read(temp, , )) > )
{
buffer.Write(temp, , count);
} return System.Text.Encoding.GetEncoding("utf-8").GetString(buffer.GetBuffer());//.UTF8.GetString();
}
catch
{
return String.Empty;
}
}
 private void GetInfo(string url, string araeCode)
{ string html = GetHtml(url);
if (string.IsNullOrWhiteSpace(html))
return;
html = html.Substring(, html.Length - );
int index = html.IndexOf("]}");
var javascript = new JavaScriptSerializer();
html = html.Substring(, index);//},{
var a = html.Split(',');
List<area> areaLst = new List<area>();
for (int i = ; i < a.Length; i = i + )
{
area area = new area();
area.id = a[i].Substring(, a[i].Length - );
area.zrange = a[i + ] + a[i + ];
area.layer = a[i + ];
area.epoch = a[i + ];
areaLst.Add(area);
}
foreach (var item in areaLst)
{
string tmpurl = string.Format(areaInfoStr, item.id);
string insertHtml = GetHtml(tmpurl);
string tmp = insertHtml;
string baseStr = string.Empty;
int indexTitle = tmp.IndexOf("base:");
if (indexTitle != -)
{
tmp = tmp.Substring(indexTitle + , tmp.Length - indexTitle - );
indexTitle = tmp.IndexOf("]");
if (indexTitle != -)
{
baseStr = tmp.Substring(, indexTitle);
tmp = tmp.Substring(indexTitle, tmp.Length - indexTitle);
}
}
List<AreaInfo> strLst = new List<AreaInfo>();
while (true)
{
AreaInfo areaInfo = new AreaInfo();
areaInfo.Offset = baseStr;
areaInfo.AreaCode = araeCode;//行政区划码
areaInfo.ID = Guid.NewGuid();
string aStr = string.Empty;
indexTitle = tmp.IndexOf("a:");
if (indexTitle != -)
{
tmp = tmp.Substring(indexTitle + , tmp.Length - indexTitle - );
indexTitle = tmp.IndexOf("]");
if (indexTitle != -)
{
aStr = tmp.Substring(, indexTitle);
areaInfo.InnerOffset = aStr;
tmp = tmp.Substring(indexTitle, tmp.Length - indexTitle);
}
} indexTitle = tmp.IndexOf("title:");
if (indexTitle != -)
{
tmp = tmp.Substring(indexTitle + , tmp.Length - indexTitle - );
//获取小区信息
indexTitle = tmp.IndexOf(",");
if (indexTitle != -)
{
string araeName = tmp.Substring(, indexTitle).Replace("\\", "").Replace("\"", "");
areaInfo.Name = araeName;
if (!strLst.Exists(p => p.Name == araeName))
{
strLst.Add(areaInfo);
//lsvAreaInfo.Items.Add(araeName);
}
tmp = tmp.Substring(indexTitle, tmp.Length - indexTitle);
}
}
else
{
break;
}
Thread.Sleep();
Application.DoEvents();
} Application.DoEvents();
Thread.Sleep(); }
}

至此我们就可以通过代码来获取google地图中你需要获取的信息。 此案例为获取全国小区信息。 当然我们需要获取其他查询的信息也是可行的。 具体的数据分析我并没用测试。但是原理应该是一样的。希望对你有帮助。

当然我的这个抓去时间主要是由于google的单用户访问次数有关。 可以购买相关的google产品获取想要的数据。

根据google地图抓去全国信息- 抓去全国小区以及新建楼盘信息的更多相关文章

  1. Google地图路线规划

    Google地图路线规划: 需求:给定的两点之间Google地图路径规划和详情. 代码实现: //map定义省略 var directionsDisplay = new google.maps.Dir ...

  2. Google 地图 API V3 使用入门

    Google官方教程: Google 地图 API V3 使用入门 Google 地图 API V3 针对移动设备进行开发 Google 地图 API V3 之事件 Google 地图 API V3 ...

  3. Google 地图 API V3 针对移动设备进行开发

    Google官方教程: Google 地图 API V3 使用入门 Google 地图 API V3 针对移动设备进行开发 Google 地图 API V3 之事件 Google 地图 API V3 ...

  4. Google 地图 API V3 之事件

    Google官方教程: Google 地图 API V3 使用入门 Google 地图 API V3 针对移动设备进行开发 Google 地图 API V3 之事件 Google 地图 API V3 ...

  5. Google 地图 API V3 之控件

    Google官方教程: Google 地图 API V3 使用入门 Google 地图 API V3 针对移动设备进行开发 Google 地图 API V3 之事件 Google 地图 API V3 ...

  6. Google 地图 API V3 之 叠加层

    Google官方教程: Google 地图 API V3 使用入门 Google 地图 API V3 针对移动设备进行开发 Google 地图 API V3 之事件 Google 地图 API V3 ...

  7. Flex加载google地图、百度地图以及天地图作底图

    一  Flex加载Google地图作底图 (1)帮助类GoogleLayer.as /* * 根据输入的地图类型加载Google地图(by chenyuming) */ package Layers ...

  8. 20+ 个很有用的 jQuery 的 Google 地图插件

    转自:http://www.oschina.net/translate/20-useful-jquery-google-maps-plugins Google 地图在寻找我们想要了解的商店或者其它有趣 ...

  9. Google地图接口API之Google地图 API 参考手册(七)

    Google 地图API 参考手册 地图 构造函数/对象 描述 Map() 在指定的 HTML 容器中创建新的地图,该容器通常是一个DIV元素. 叠加层 构造函数/对象 描述 Marker 创建一个标 ...

随机推荐

  1. mysql日期格式化

    DATE_FORMA T(date, format) 根据格式串format 格式化日期或日期和时间值date,返回结果串. 可用DATE_FORMAT( ) 来格式化DATE 或DATETIME 值 ...

  2. Zabbix监控disk performance

    概述 zabbix获取/sys里面的磁盘信息并分析来监控disk performance sysfs是Linux内核中设计较新的一种虚拟的基于内存的文件系统,它的作用与 proc 有些类似(默认挂载在 ...

  3. miniui无法传递input值

    miniui获取到的值死活传不到php去处理,input框里有值php接收到却一直为空,又是查资料.测试.搜索.提问,最后才在文档中发现尼玛miniui不用name的,其实是<input tex ...

  4. mysql关联表的复制

    1. 复制被参照的表: CREATE TABLE clone_product_1 LIKE product_1; INSERT INTO clone_product_1 SELECT * FROM p ...

  5. jedis池的作用

    一.jedis池的介绍 相信大家都用过线程池或者是jdbc的连接池,使用池可以减少系统在使用所需对象时创建对象的开销,从而提高系统性能和效率.jedis池也是如此,那么我们该如何使用jedis池呢? ...

  6. Java中vector的使用详解

    Vector 可实现自动增长的对象数组. java.util.vector提供了向量类(vector)以实现类似动态数组的功能.在Java语言中没有指针的概念,但如果正确灵活地使用指针又确实可以大大提 ...

  7. nltk27_NLTK聚类分析

    http://www.pythontip.com/blog/post/10044/ Python自然语言处理(三) -- 利用NLTK进行聚类 这篇文章介绍如何利用NLTK进行聚类,和上两篇文章Pyt ...

  8. nginx图片处理

    前言 不管一个系统或网站的大与小,都存在相应的图片处理,生成缩略图.为图片加水印等等,如果涉及到APP端,这个图片的处理需求变得更加重要了,因为在目前看来,客户端的屏幕大小不一,会导致以下问题: 1. ...

  9. 如何在网页中添加“QQ交流”

    今天在撸码时,想到这个问题,有些网页中会有诸如,那么如何在网页添加"QQ交谈"? 第一步.登录QQ: 第二步.打开网页:QQ推广,启用QQ通讯组件: 第三步.选择组件样式,设置提示 ...

  10. MySql 外键约束 之CASCADE、SET NULL、RESTRICT、NO ACTION分析和作用

    MySQL有两种常用的引擎类型:MyISAM和InnoDB.目前只有InnoDB引擎类型支持外键约束.InnoDB中外键约束定义的语法如下: ALTER TABLE tbl_name ADD [CON ...