文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python爬取地图瓦片

2023-01-30 23:36

关注

由于要在内网开发地图项目,不能访问在线的地图服务了,就想把地图瓦片下载下来,网上找了一些下载器都是需要注册及收费的,否则下载到的图都是打水印的,如下:

因为地图瓦片就是按照层级、行、列规则组织的一张张图片(如下图,14是瓦片的级别,13478是行号,6202是列号),所以想到可以试试用python把这些图爬取下来。

主要可以分为三步:

1.确定要下载的瓦片的级别,经度和纬度范围(可以通过百度坐标拾取获得,http://api.map.baidu.com/lbsapi/getpoint/index.html)

2.计算出这个范围内瓦片的起始和终止行列号

1 # 经纬度反算切片行列号 3857坐标系
2 def deg2num(lat_deg, lon_deg, zoom):
3     lat_rad = math.radians(lat_deg)
4     n = 2.0 ** zoom
5     xtile = int((lon_deg + 180.0) / 360.0 * n)
6     ytile = int((1.0 - math.log(math.tan(lat_rad) + (1 / math.cos(lat_rad))) / math.pi) / 2.0 * n)
7     return (xtile, ytile)

3.根据行列号拼接出瓦片的url地址

1 #Google地图瓦片为例,zoom是地图层级,x,y为行列号
2 tilepath = 'http://www.google.cn/maps/vt/pb=!1m4!1m3!1i'+str(zoom)+'!2i'+str(x)+'!3i'+str(y)+'!2m3!1e0!2sm!3i345013117!3m8!2szh-CN!3scn!5e1105!12m4!1e68!2m2!1sset!2sRoadmap!4e0'

下载图片

 1 # 下载图片
 2 def getimg(Tpath, Spath, x, y):
 3     try:
 4         f = open(Spath, 'wb')
 5         req = urllib.request.Request(Tpath)
 6         req.add_header('User-Agent', random.choice(agents))  # 换用随机的请求头
 7         pic = urllib.request.urlopen(req, timeout=60)
 8         f.write(pic.read())
 9         f.close()
10         print(str(x) + '_' + str(y) + '下载成功')
11     except Exception:
12         print(str(x) + '_' + str(y) + '下载失败,重试')
13         getimg(Tpath, Spath, x, y)

保存图片时也需要按照层级,行创建好目录存储

1 path = "D:\\GoogleImg\\" + str(zoom) + "\\" + str(x)
2     if not os.path.exists(path):
3         os.makedirs(path)

结果如下:

用Openlayers加载出来的效果和在线地图是一样的。

Python获取地图瓦片的完整代码

Openlayers加载离线瓦片参考例子

Leaflet加载离线瓦片参考例子

如果对您有用,请赞赏!谢谢!

 

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯