GIS热力图制作与位置大数据分析
最近有很多朋友咨询位置数据、热力图等等东西,我一一进行了解答,但是个人精力实在有限,特写一个博客进行详细技术说明,其实这个东西位置数据、百度地图POI、高德地图POI等数据爬取、存储都较为简单,热力图渲染也较为简单,只要找到了好的库就很快了。
首先,我们采用百度地图API爬取长沙市和深圳相关地区的一些POI兴趣点,技术参考:https://blog.csdn.net/suwenkun1126/article/details/78343150,这个就是使用了SQL数据库进行了存储,高德地图POI爬取:https://blog.csdn.net/qq_34464926/article/details/79128211,这些都比较简单,稍微修改即可使用,好了,闲话不多说,我们爬取一些POI点如下所示:

里面的格式我展开给大家看一下,

上面图中就是对应的经度纬度等等信息。
如果只从SQL数据或者XSL中来看,实在看不出来有什么很大的名堂,比如说某个单位特别想看一下长沙市的人口大致分布情况、长沙市的医院分布情况、长沙市的小学分布情况,这些文字就没什么意思了,那么我们就需要空间分析了,其中热力图就是最有意思的东西。
下面我们上一下热力图成果:

腾讯位置大数据热力图

深圳南山区腾讯位置大数据热力图

长沙市小学分布图
这个图就有点意思了,我们来看一下长沙市的教育资源分布情况(PS:马上小小王也要读小学了,赶紧研究一下),总体来看,小学分布最密集的地方就是开福区和雨花区、岳麓区,最贫乏的地区就是天心区(完了,小小王没得书读了)。
下面再来看一下长沙市的医院分布热力图:

长沙市医院分布热力图
从这个图可以看出,医院何药店分布密集的区域为环梅溪湖区域,五一广场到芙蓉广场。
下面我们再来看一下最劲爆的热力图—长沙市情趣用品店分布热力图:

长沙市情趣用品店分布图
这个就没啥意思了,我看了一下,分布在这几个区域:湖南第一师范对面(为什么主席母校对面有这么多情趣店?手动疑问),城南街道(这个没啥好说的),星沙部分区域,这个就没啥好说的了。
关于代码如何实现,我这里把code贴下来,供大家参考。
# coding:utf-8
import os
import folium
import numpy as np
from folium.plugins import HeatMap
import xlrd
# written by Mr wang,refer:https://blog.csdn.net/LaoChengZier/article/details/83684961
# date:2019-4-1 # 读取POI文本
def readExel(filePath):
wb = xlrd.open_workbook(filePath) # 打开文件 sheet1 = wb.sheet_by_index(0) # 通过索引获取表格 length = sheet1.nrows # 数据行数 latitude = list(map(float, sheet1.col_values(1)[1:length])) # 批量将string字符转成float类型 longitude = list(map(float, sheet1.col_values(0)[1:length])) num = sheet1.col_values(2)[1:length] Latitude = np.array(latitude) Longitude = np.array(longitude) Num = np.array(num) return np.hstack((Latitude.reshape(Latitude.shape[0], 1),
Longitude.reshape(Longitude.shape[0], 1), Num.reshape(Num.shape[0], 1))) filePath = r'C:\Users\Administrator\Desktop\高德地图POI-python\长沙_QX.xls' data = readExel(filePath) m = folium.Map([26., 112.], tiles='OpenStreetMap', zoom_start=5) # 自定义底图 HeatMap(data).add_to(m) m.save(os.path.join(r'C:\Users\Administrator\Desktop\高德地图POI-python', 'MyHeatmap.html'))
这里面主要用到了一个folium库,这个库比较简单易用,推荐大家使用,在这里我自己也做一个笔记,就是这个numpy库的一维向量转置,这个不能用transposed方法,这里特别备注一下。
关于百度地图API和高德地图API爬取POI信息,由于这里面用到了我的付费账号,就不能大家了,如果有需要,可以联系qq:1044625113,如果大家有技术问题,也欢迎随时交流!
GIS热力图制作与位置大数据分析的更多相关文章
- Splunk大数据分析经验分享
转自:http://www.freebuf.com/articles/database/123006.html Splunk大数据分析经验分享:从入门到夺门而逃 Porsche 2016-12-19 ...
- 用Storm轻松实时大数据分析【翻译】
原文地址 简单易用,Storm让大数据分析变得轻而易举. 如今,公司在日常运作中经常会产生TB(terabytes)级的数据.数据来源包括从网络传感器捕获的,到Web,社交媒体,交易型业务数据,以及其 ...
- 使用Storm实现实时大数据分析
摘要:随着数据体积的越来越大,实时处理成为了许多机构需要面对的首要挑战.Shruthi Kumar和Siddharth Patankar在Dr.Dobb’s上结合了汽车超速监视,为我们演示了使用Sto ...
- 大数据分析神兽麒麟(Apache Kylin)
1.Apache Kylin是什么? 在现在的大数据时代,越来越多的企业开始使用Hadoop管理数据,但是现有的业务分析工具(如Tableau,Microstrategy等)往往存在很大的局限,如难以 ...
- 【ActiveReports 大数据分析报告】用数据分析的手段告诉你,复联4有多火爆?
消失的人们会回来吗,奇异博士所说的1400万分之一可能性究竟是什么,还会有谁逝去? 4月24日零时,随着万众期待的<复仇者联盟4>(以下简称<复联4>)正式上映,一切谜底都将揭 ...
- ActiveReports 大数据分析报告:2019软件开发者现状
“C++很不错,PHP是世界上最好的语言,所以我选Java …” 在全球软件开发者群体中,关于最优语言与最优框架的争论从未停止. 本次 ActiveReports 大数据分析报告,将借助权威数据,为您 ...
- ActiveReports 大数据分析报告:2018中国电影再次迎来黄金时代
回顾2018,中国电影市场收获颇丰.先是凭借春节档<红海行动>.<唐人街探案>双双实现30亿票房突破,而后暑期档火力全开,<我不是药神>.<西虹市首富> ...
- ActiveReports 大数据分析报告:贸易争端与中国企业数字化转型
2018年11月12日至18日,亚太经合组织(APEC)领导人非正式会议首次在南太平洋最大岛国巴布亚新几内亚的首都莫尔兹比港举行,本次会议的主题是:“把握包容性机遇,拥抱数字化未来”. 面对全球不断变 ...
- 大数据分析界的“神兽”Apache Kylin有多牛?【转】
本文作者:李栋,来自Kyligence公司,也是Apache Kylin Committer & PMC member,在加入Kyligence之前曾就职于eBay.微软. 1.Apache ...
随机推荐
- 聊聊PROFINET与PROFIBUS
1.PROFINET与PROFIBUS从狭义上比,没有可比性,因为他们的物理接口不同,电气特性,不同,波特率不同,电气介质特性不同等等.这样两者的协议是完全没有关联性的,唯一的关联性就是两者都是PI组 ...
- Gamma 函数及其应用
1. Γ(⋅) 函数定义 Γ(α)=∫∞0tα−1e−tdt 可知以下基本性质: Γ(α+1)=αΓ(α)(分部积分法) Γ(1)=1 ⇒ Γ(n+1)=n! Γ(12)=π√ 2. 常见变形 对于 ...
- Java反射获取内部类有局限
这周接触到继承及修改具有包访问权的内部类内容,略梳理了下各种资料,发觉在包外修改内部类内容必须通过实例....... 网上关于这部分的内容比较少,参考了下这位的帖子:http://blog.csdn. ...
- 一言不合就写socket的post和get请求(拼内容,然后发出去即可)
一言不合就写socket的post和get请求.写个桌面程序,利用java写get和post请求.测试成功: SocketReq.java package com.test.CipherIndex; ...
- 记一次由于缓存导致的bug
bug描述 有一张数据库表存储的是 值日员工信息,有时候可能一次性录入1个月的数据.有时候也可能隔了很多天没有录入数据,也就是说这个录数据不是很规律. bug现象:测试人员发现,网站上三亚地区能正常显 ...
- python3 操作注册表
1.1 读取 import winreg key = winreg.OpenKey(winreg.HKEY_CURRENT_USER,r"Software\Microsoft\Windows ...
- js到字符串数组,实现阵列成一个字符串
数组字符串(阵列元件与字符串连接) var a, b; a = new Array(0,1,2,3,4); b = a.join("-"); 字符串转数组(根据一个字符串被分成 ...
- 使用Qt installer framework制作安装包(不知道是否适合Mac和Linux?)
一.介绍 使用Qt库开发的应用程序,一般有两种发布方式:(1)静态编译发布.这种方式使得程序在编译的时候会将Qt核心库全部编译到一个可执行文件中.其优势是简单单一,所有的依赖库都集中在一起,其缺点也很 ...
- AngularJS ng-if使用
示例中,根据ng-if指令显示不同任务状态,以及判断任务是否可以操作 <div ng-app="NgifDemoApp" ng-controller="NgifDe ...
- C# API 获取系统DPI缩放倍数跟分辨率大小
原文:C# API 获取系统DPI缩放倍数跟分辨率大小 using System; using System.Drawing; using System.Runtime.InteropServices ...