京公网安备 11010802034615号
经营许可证编号:京B2-20210330
R语言做地图上的分析
R和ggplot可视化功能非常强大,了解了一下其中的地图做法,发现R做世界地图、美国地图非常容易,但做中国地图就太麻烦了,需要自己DIY。
DIY也有多种方式,但网络上各种帖子教程的出图效果都不太理想,达不到工作用要求。下面是我的摸索过程,记录如下备忘,也请教于R老师们。
0、引子
R里有个绘制地图的maps包,加载后即可绘制地图,试一下以下命令:
library(maps)
map()
即可画出一个世界地图。再试试:
map("state")
map("county")
可分别画出美国分州和分county的地图,真是不费吹灰之力。
可是,要画一幅中国地图,就没有这么容易了,需要先加载一个mapdata包:
library(mapdata)
map("china")
但发现居然还是没有重庆的地图,太坑爹了,没法用,只有自己构造中国地图了。下面开始进入正题,如何用R绘制中国分省热力地图。
1、准备地图数据
先要找到中国地图数据文件。到国家基础地理信息中心的网站(http://nfgis.nsdi.gov.cn)下载官方空间文件,但这个政府网站总是打不开!你可到微信公众号 iamExcelPro 发送 shapefile 获得下载地址,我是雷锋。解压到 c:/rstudy 目录,有3个文件,都是需要的。
加载maptools包,读取空间文件:
library("maptools")
china_map = readShapePoly("c:/rstudy/bou2_4p.shp") # 读取地图空间数据
plot一下看看,是一幅中国地图,有重庆,还包括南海的岛屿,政府数据就是严谨一些:
plot(china_map)
但地图投影方式不对,看起来太扁了,完全不是我们常见的昂首雄鸡状。
加载ggplot2包,用ggplot绘制,并使用polyconic投影方式,显示正常。
library(ggplot2)
ggplot(china_map,aes(x=long,y=lat,group=group)) +
geom_polygon(fill="white",colour="grey") +
coord_map("polyconic")
现在地图是可用的了,但还需要加载和拼接行政信息,以便能与业务数据映射。
x <- china_map@data #读取行政信息
xs <- data.frame(x,id=seq(0:924)-1) #含岛屿共925个形状
library(ggplot2)
china_map1 <- fortify(china_map) #转化为数据框
library(plyr)
china_map_data <- join(china_map1, xs, type = "full") #合并两个数据框
提示:Joining by: id
看不懂?没关系,过了就行。
2、准备业务数据
网上教程居然都是在命令行里输入数据,也很坑爹。我们还是从Excel表格转存来得方便。
按以下格式准备好指标数据,并存为csv格式文件。不直接读取xlsx文件是因为需要装的包比较麻烦。
注意第1列的字段名为NAME,各省名称也是要固定一致的,是为了和地图数据框里的省名一致,便于合并。各省名称是用以下命令查看并记下的。
> unique(china_map@data$NAME)
[1] 黑龙江省 内蒙古自治区 新疆维吾尔自治区 吉林省
[5] 辽宁省 甘肃省 河北省 北京市
[9] 山西省 天津市 陕西省 宁夏回族自治区
[13] 青海省 山东省 西藏自治区 河南省
[17] 江苏省 安徽省 四川省 湖北省
[21] 重庆市 上海市 浙江省 湖南省
[25] 江西省 云南省 贵州省 福建省
[29] 广西壮族自治区 台湾省 广东省 香港特别行政区
[33] 海南省
下面读取业务指标数据,并与地图数据合并:
mydata <- read.csv("c:/rstudy/geshengzhibiao.csv") #读取指标数据,csv格式
china_data <- join(china_map_data, mydata, type="full") #合并两个数据框
提示:Joining by: NAME
3、绘制地图
现在可以开始试试画填色地图了:
ggplot(china_data, aes(x = long, y = lat, group = group, fill = zhibiao)) +
geom_polygon(colour="grey40") +
scale_fill_gradient(low="white",high="steelblue") + #指定渐变填充色,可使用RGB
coord_map("polyconic") #指定投影方式为polyconic,获得常见视角中国地图
好,看到填色地图了,但图中的背景色、坐标轴、经纬线都是不需要的,图例也可以放到左下角,用theme命令清除:
ggplot(china_data, aes(x = long, y = lat, group = group,fill = zhibiao)) +
geom_polygon(colour="grey40") +
scale_fill_gradient(low="white",high="steelblue") + #指定渐变填充色,可使用RGB
coord_map("polyconic") + #指定投影方式为polyconic,获得常见视角中国地图
theme( #清除不需要的元素
panel.grid = element_blank(),
panel.background = element_blank(),
axis.text = element_blank(),
axis.ticks = element_blank(),
axis.title = element_blank(),
legend.position = c(0.2,0.3)
)
4、添加省名标签
有时候需要显示省名标签,特别是给老领导看。可根据每个省形状的经纬度平均值求近似中心位置,标注省名。
midpos <- function(x) mean(range(x,na.rm=TRUE))#取形状内的平均坐标
centres <- ddply(china_data,.(province),colwise(midpos,.(long,lat)))
ggplot(china_data,aes(long,lat))+ #此处语法与前面不同,参考ggplot2一书P85
geom_polygon(aes(group=group,fill=zhibiao),colour="black")+
scale_fill_gradient(low="white",high="steelblue") +
coord_map("polyconic") +
geom_text(aes(label=province),data=centres) +
theme(
panel.grid = element_blank(),
panel.background = element_blank(),
axis.text = element_blank(),
axis.ticks = element_blank(),
axis.title = element_blank()
)
但发现海南两个字跑到南海去了,不行。下面改使用省会城市的经纬度数据标注省名。
province_city <- read.csv("c:/rstudy/chinaprovincecity.csv") #读取省会城市坐标
ggplot(china_data,aes(long,lat))+
geom_polygon(aes(group=group,fill=zhibiao),colour="grey60")+
scale_fill_gradient(low="white",high="steelblue") +
coord_map("polyconic") +
geom_text(aes(x = jd,y = wd,label = province), data =province_city)+
theme(
panel.grid = element_blank(),
panel.background = element_blank(),
axis.text = element_blank(),
axis.ticks = element_blank(),
axis.title = element_blank()
)
至此,终于DIY绘制出了一份中国分省的热力地图,真是够折腾够找虐的,好在图形很精准,以后也可以复用代码。
所以结论就是,一般非专业用户还是使用BingMap、PowerMap、Tableau或者《用地图说话》中的Excel模板,直接填数据出地图吧,其中Excel模板方式是最简单、便携,office协同性最好的。
如果你想用这些代码出图,可准备好用到的3个文件到相应目录,其中一个是你的业务指标csv文件,一步步运行以上代码,应该就可得到一幅中国地图。
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
主讲人简介 张冲,海归统计学硕士,CDA 认证数据分析师,前云南白药集团资深数据分析师,自媒体 Python 讲师,全网课程播放量破 ...
2026-04-10在数据可视化与业务分析中,同比分析是衡量业务发展趋势、识别周期波动的核心手段,其核心逻辑是将当前周期数据与上年同期数据进 ...
2026-04-10在机器学习模型的落地应用中,预测精度并非衡量模型可靠性的唯一标准,不确定性分析同样不可或缺。尤其是在医疗诊断、自动驾驶、 ...
2026-04-10数据本身是沉默的,唯有通过有效的呈现方式,才能让其背后的规律、趋势与价值被看见、被理解、被运用。统计制图(数据可视化)作 ...
2026-04-10在全球化深度发展的今天,跨文化传播已成为连接不同文明、促进多元共生的核心纽带,其研究核心围绕“信息传递、文化解读、意义建 ...
2026-04-09在数据可视化领域,折线图是展示时序数据、趋势变化的核心图表类型之一,其简洁的线条的能够清晰呈现数据的起伏规律。Python ECh ...
2026-04-09在数据驱动的时代,数据分析早已不是“凭经验、靠感觉”的零散操作,而是一套具备固定逻辑、标准化流程的系统方法——这就是数据 ...
2026-04-09长短期记忆网络(LSTM)作为循环神经网络(RNN)的重要改进模型,凭借其独特的门控机制(遗忘门、输入门、输出门),有效解决了 ...
2026-04-08在数据分析全流程中,数据质量是决定分析结论可靠性的核心前提,而异常值作为数据集中的“异类”,往往会干扰统计检验、模型训练 ...
2026-04-08在数字经济飞速发展的今天,数据已渗透到各行各业的核心场景,成为解读趋势、优化决策、创造价值的核心载体。而数据分析,作为挖 ...
2026-04-08在数据分析全流程中,数据处理是基础,图形可视化是核心呈现手段——前者负责将杂乱无章的原始数据转化为干净、规范、可分析的格 ...
2026-04-07在数据分析与统计推断中,p值是衡量假设检验结果显著性的核心指标,其本质是在原假设(通常为“无效应”“无差异”)成立的前提 ...
2026-04-07在数字经济深度渗透的今天,数据已成为企业生存发展的核心资产,企业的竞争本质已转变为数据利用能力的竞争。然而,大量来自生产 ...
2026-04-07Python凭借简洁的语法、丰富的生态库,成为算法开发、数据处理、机器学习等领域的首选语言。但受限于动态类型、解释性执行的特性 ...
2026-04-03在深度学习神经网络中,卷积操作是实现数据特征提取的核心引擎,更是让模型“看懂”数据、“解读”数据的关键所在。不同于传统机 ...
2026-04-03当数字化转型从企业的“战略口号”落地为“生存之战”,越来越多的企业意识到,转型的核心并非技术的堆砌,而是数据价值的深度挖 ...
2026-04-03在日常办公数据分析中,数据透视表凭借高效的汇总、分组功能,成为Excel、WPS等办公软件中最常用的数据分析工具之一。其中,“计 ...
2026-04-02在数字化交互的全场景中,用户的每一次操作都在生成动态的行为轨迹——电商用户的“浏览商品→点击详情→加入购物车”,内容APP ...
2026-04-02在数字化转型深度推进的今天,企业数据已成为驱动业务增长、构建核心竞争力的战略资产,而数据安全则是守护这份资产的“生命线” ...
2026-04-02在数据驱动决策的浪潮中,数据挖掘与数据分析是两个高频出现且极易被混淆的概念。有人将二者等同看待,认为“做数据分析就是做数 ...
2026-04-01