整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

用Python画中国地图,实现各省份数据可视化

一步:安装pyecharts

pyecharts是一款将python与echarts结合的强大的数据可视化工具,本文使用了0.1.9.4版本

pip install pyecharts==0.1.9.4

第二步:读取数据

我的数据是在Excel表格里,如下图:

Execel数据

使用xlrd(没有就通过pip install xlrd安装)读取Excel表格中的数据

from pyecharts import Map
import xlrd
# 第一种方式,使用xlrd读取Execel表格中数据
data = xlrd.open_workbook('data.xlsx')
table = data.sheet_by_name('Sheet1')
province = table.col_values(0)[1:]
num = table.col_values(1)[1:]

如果各位没有相应的Execel文件,也不想新建一个,那就干脆自己定义一个字典,其中键是省份,值是对应的数量,然后再把对应的值取出来

# 第二种方式,直接自己写一个字典,然后取出相应数据
province_distribution = {'四川': 239.0, '浙江': 231.0, '福建': 203.0, '江苏': 185.0, '湖南': 152.0, '山东': 131.0, '安徽': 100.0, '广东': 89.0, '河北': 87.0, '湖北': 84.0, '吉林': 75.0,  
                         '上海': 70.0, '江西': 64.0, '广西': 64.0, '贵州': 64.0, '北京': 63.0, '云南': 53.0, '重庆': 49.0, '河南': 48.0, '陕西': 38.0, '山西': 37.0, '辽宁': 33.0, '新疆': 25.0, 
                         '内蒙古': 23.0, '黑龙江': 20.0, '天津': 19.0, '甘肃': 13.0, '海南': 9.0, '青海': 7.0, '宁夏': 4.0, '西藏': 0.0}
provice = list(province_distribution.keys())
num = list(province_distribution.values())

第三步:画图

chinaMap = Map(width=1200, height=600)
chinaMap.add(name="分布数量",
             attr=province,
             value=num,
             visual_range=[0, 239],
             maptype='china',
             is_visualmap=True)
chinaMap.render(path="中国地图.html")
  • 其中参数name指的是显示在地图正上方的标题,
  • attr就是一个包含了各省份名称的列表,
  • value就是包含了各省份对应数值的列表,
  • visual_range指的是整个数据中的数值范围,
  • maptype就是指的地图类型,
  • is_visualmap代表是否显示颜色

这时候就会生成一个名称为“中国地图.html”的文件,打开后如下图所示:

无省份名称地图

如果想保存为图片,可以点击地图右侧的下载按钮,因为隔着比较远,我在录屏的时候并没有把下载按钮录进来,但大家在自己电脑上肯定会看见的。

第四步:进一步优化

大家可以看到上图中各省份的名称只有在被鼠标选中的情况下,才能显示,并且所保存的图片也不会显示各省份名称,如果要显示各省份名称,则需要对html文件就行修改,推荐使用notepad++(一个文本编辑软件,直接去百度上下载,很简单的)打开“中国地图.html”文件,然后在第1923行的那个series中添加"label":{ "normal":{ "show":true}},并保存,如下:

修改html文件

然后再打开“中国地图.html”文件,就可以看到各省份的名称啦,如下图:

有省份名称地图


你以为你真的掌握了吗?请进传送门:用Python画江苏省地图,实现各地级市数据可视化

关注微信公众号“Python小镇”,发现更多干货知识!

Echarts 无论是制作省份地图还是区县域地图,他们的步骤都是基本一样的。

下面本人就 利用 Echarts 简单绘制省份地图 的步骤与经验与各位分享一下。

1、准备工作

  • 1.1 下载js静态文件china.jsecharts.min.js

  • 1.2 下载中国各省、各市的 .json 文件省份或者地区的数据文件网址:https://github.com/longwosion/geojson-map-china

2、获取省份数据

  • 2.1 第一步:获取XX省的地图 json 数据文件(例:江苏省:32.json)(是以各省身份证号 前两位 开头命名的)
  • 2.2 第二步:将获取到的JSON文件 转换 成 js 文件(江苏省:jiangsu.js)
  • 2.3 第三步:修改转换后的 js 文件 打开 js 文件添加变量 xx (这里本人命名习惯为 :(省名拼音小写+Json)例:jiangsuJson)var xx = (js文件)
  • 例:
      var jiangsuJson = {"type": "FeatureCollection","cp":[118.8586,32.915], ........}保存 js 文件。

3、在Django中编写 HTML 代码

  • 3.1 在<head> </head>中引入 js 文件
<script type="text/javascript" src="/static/js/echarts.min.js"></script>
<script type="text/javascript" src="/static/js/jiangsu.js"></script>
  • 3.2 在<body></body>中写入作图代码
<div>
    {# 标记 #}
     <a class="btn btn-success btn-sm" >江苏省</a>
    {# 地图代码开始 #}
     <div class="x-body">
         <!-- 为ECharts准备一个具备大小(宽高)的Dom -->
         <div id="main" style="width: 949.75px;height:450px;"></div>
         </div>
                    
         <script type="text/javascript">
               echarts.registerMap('jiangsu', jiangsuJson);

               // 基于准备好的dom,初始化echarts实例
               var myChart = echarts.init(document.getElementById('main'));

               // 使用刚指定的配置项和数据显示图表。
               myChart.setOption({
                   series: [{
                       type: 'map',
                       map: 'jiangsu'
                       }]
                });
           </script>                    
</div>
  • 3.3 运行代码,就能看到结果

4、总结

其实只要按照本人上面的做法,就可以制作出来,本人绘不是很复杂,如果各位对省图还需要其他显示功能,大家不妨访问 Echarts 的官网。

标准地图依据中国和世界各国国界线画法标准编制而成,可用于新闻宣传用图、书刊报纸插图、广告展示背景图、工艺品设计底图等,也可作为编制公开版地图的参考底图。社会公众可以免费浏览、下载标准地图,直接使用标准地图时需要标注审图号。

标准地图有JPG、EPS两种数据格式,地图幅面分为64开、32开、16开、8开、4开、对开等。需要编辑EPS格式地图时,建议使用Adobe Illustrator软件。对地图内容编辑(包括放大、缩小和裁切)改动的,公开使用前需要送自然资源主管部门审核。

目前发布的标准地图包括:中国地图269幅,世界地图79幅,专题地图11幅。

全国标准地图服务 :http://bzdt.ch.mnr.gov.cn/

各省标准地图服务:
1、北京市:https://beijing.tianditu.gov.cn/bzdt/

2、天津市:https://tianjin.tianditu.gov.cn/static/html/bzmap.html

3、河北省:http://hebei.tianditu.gov.cn/bzdt/

4、山西省:http://zrzyt.shanxi.gov.cn/zwgk/bzdt/sxsdt/
5、内蒙古自治区:http://zrzy.nmg.gov.cn/bsfw/bzdt/

6、辽宁省:http://liaoning.tianditu.gov.cn/standardmap/index.html
7、吉林省:
https://jilin.tianditu.gov.cn/liquor-viewer/standardMap.do?type=1
8、黑龙江省:
http://hlsm.mnr.gov.cn/ggfw/xzfw/2c907f087167b849017167c321fa060f.html
9、上海市:
http://shanghai.tianditu.gov.cn/map/views/standardMap.html

10、江苏省:http://zrzy.jiangsu.gov.cn/jsbzdt/index.html
11、浙江省:https://zhejiang.tianditu.gov.cn/standard
12、安徽省:https://zrzyt.ah.gov.cn/ztlm/ahsbzdtfw/index.html
13、福建省:http://bzdt.fjmap.net/
14、江西省:http://bnr.jiangxi.gov.cn/col/col45382/index.html
15、山东省:http://bzdt.shandongmap.cn/home
16、河南省:http://www.hncehui.cn/plus/view.php?aid=7534
17、湖北省:https://hubei.tianditu.gov.cn/standardMap
18、湖南省:
https://hunan.tianditu.gov.cn/TDTHN/tjxz/index.html
19、广东省:http://nr.gd.gov.cn/map/bzdt/
20、广西壮族自治区:
https://www.gismap.com.cn/webmap/index.html#/webmap/index
21、海南省:http://hism.mnr.gov.cn/sjkf/bzdt/index.html
22、重庆市:http://ghzrzyj.cq.gov.cn/dt/foot.html
23、四川省:http://scsm.mnr.gov.cn/nbzdt.htm
24、贵州省:
https://zrzy.guizhou.gov.cn/wzgb/zwgk/zdlyxxgk/dlxxgl/dtfw/bzdt1/index.html
25、云南省:https://yunnan.tianditu.gov.cn/MapResource
26、西藏自治区:
http://zrzyt.xizang.gov.cn/fw/zyxz/202004/t20200430_139102.html
27、陕西省:
http://snsm.mnr.gov.cn/Information/BiaoZhunDiTuPage/1131


28:甘肃省:
https://gansu.tianditu.gov.cn/gsstdmap/startpg/index.html
29、青海省:http://qinghai.tianditu.gov.cn/qhbzmap/
30、宁夏回族自治区:https://ningxia.tianditu.gov.cn/tuji
31、新疆维吾尔自治区:
https://xinjiang.tianditu.gov.cn/main/bzdt.html
32、新疆生产建设兵团:http://zrzy.xjbt.gov.cn/bzdtfw/


来源请引用:地理遥感生态网科学数据注册与出版系统