最近开发时要实现一个业务逻辑:

  • 调用中国气象数据网API接口获取广东省实时气象数据
  • 根据数据,基于广东省地图渲染等压线图

最终效果图是这样的:

  • 首先是获取实时气压数据,由于中国气象数据网每次只能获得30个站点的气象数据,而广东省共有86个气象站点,所以分成3批获取,存入数组。

    获取到的数据格式是[{Station_Id_C,Year,Mon,Day,Hour,PES}],然后遍历气象站点列表,把对应的经纬度(longitude、latitude)存入数组中,得到了这样的三元组数组(longitude、latitude、value),用pandas处理一下:
x = df['longitude'].values
y = df['latitude'].values
z = df[request.GET.get("c")].values
  • 然后通过numpy库中的 meshgrid 函数把x、y两个一维数组矢量化为两个二维数组X , Y = np.meshgrid(x,y)
  • 用zip函数取出所有点points = [[a, b] for a, b in zip(x, y)]
  • 使用scipy库中的 griddata 函数插值数据集,便于形成N条等压线Z = griddata(points, z, (X, Y))
  • 为了与前端采用的geojson作为地图数据统一,选用Geopands库作为地图渲染库,首先打开广东省的geojson文件df = gpd.read_file(os.path.dirname(__file__) + '\\gd.json'),然后将地图渲染到matplotlib的画布上ax = df.plot(figsize=(10, 10), alpha=0.2, edgecolor='k')
  • 利用 contour 函数将等压线渲染到画布上C = ax.contour(X, Y, Z),再标注等压线的数值plt.clabel(C, inline=True, fontsize=10)
  • 去除x轴、y轴plt.xticks(()) plt.yticks(()),调用show函数查看图像
  • 实际业务中的代码如下,为了用户下载图片浪费服务器资源,选择将静态图片保存至服务器端:
def get_contour(request):
index_url = "http://api.data.cma.cn:8090/api?"
get_params = {
"dataFormat": "json",
"interfaceId": "getSurfEleByTimeRangeAndStaID",
"dataCode": "SURF_CHN_MUL_HOR",
"timeRange": "[" + datetime.strptime(request.GET.get('f'), "%Y-%m-%dT%H:%M").strftime(
"%Y%m%d%H%M%S") + "," + datetime.strptime(request.GET.get('g'), "%Y-%m-%dT%H:%M").strftime(
"%Y%m%d%H%M%S") + "]",
"staIDs": int(request.GET.get('e')),
"elements": 'Station_Id_C,Year,Mon,Day,Hour,' + request.GET.get("c")
} session = requests.Session()
f = session.get(index_url + parse.urlencode(get_params))
s = json.loads(f.text)
l = s['DS'][len(s['DS']) - 1]
date = datetime(year=int(l['Year']), month=int(l['Mon']),
day=int(l['Day']), hour=int(l['Hour']))
s = list(DCmaStation.objects.all().values())
d = []
for i in range(int(len(s) / 30) + 1):
n = [j['id'] for j in s[i * 30: (i + 1) * 30]]
get_params = {
"dataFormat": "json",
"interfaceId": "getSurfEleByTimeRangeAndStaID",
"dataCode": "SURF_CHN_MUL_HOR",
"timeRange": "[" + date.strftime("%Y%m%d%H%M%S") + "," + date.strftime("%Y%m%d%H%M%S") + "]",
"staIDs": str(n),
"elements": 'Station_Id_C,Year,Mon,Day,Hour,' + request.GET.get("c")
}
f = session.get(index_url + parse.urlencode(get_params))
d.extend(json.loads(f.text)['DS'])
for i in d:
for j in s:
if int(i['Station_Id_C']) == int(j['id']):
i['longitude'] = j['longitude']
i['latitude'] = j['latitude']
break
df = pd.DataFrame(d)
x = df['longitude'].values
y = df['latitude'].values
z = df[request.GET.get("c")].values def plot_contour(x, y, z, resolution=50, contour_method='linear'):
resolution = str(resolution) + 'j'
X, Y = np.mgrid[min(x):max(x):complex(resolution), min(y):max(y):complex(resolution)]
points = [[a, b] for a, b in zip(x, y)]
Z = griddata(points, z, (X, Y), method=contour_method)
return X, Y, Z X, Y, Z = plot_contour(x, y, z, resolution=50, contour_method='linear')
locale.setlocale(locale.LC_CTYPE, 'chinese')
plt.rcParams['font.sans-serif'] = ['SimHei']
df = gpd.read_file(os.path.dirname(__file__) + '\\gd.json')
ax = df.plot(figsize=(10, 10), alpha=0.2, edgecolor='k')
C = ax.contour(X, Y, Z)
plt.clabel(C, inline=True, fontsize=10)
plt.xticks(())
plt.yticks(())
plt.title(
"广东省" + date.strftime("%Y年%m月%d日%H时") + "等" + DCmaDict.objects.filter(key=request.GET.get('c')).first().value+"图") filename = datetime.now().strftime("%Y%m%d%H%M%S") + ".png"
plt.savefig(os.path.dirname(__file__) + '\\static\\img\\' + filename, bbox_inches='tight')
return HttpResponse(filename)

python 画广东省等压线图的更多相关文章

  1. 用matalb、python画聚类结果图

    用matlab %读入聚类后的数据, 已经分好级别了,例如前4行是亚洲一流, %-13是亚洲二流,-24是亚洲三流 a=xlsread('C:\Users\Liugengxin\Desktop\1.x ...

  2. python画箱线图

    # -*- coding: utf-8 -*- """ Created on Wed Jun 14 13:00:11 2017 @author: Miao "& ...

  3. Python matplot画散列图

    同matlab一样,matplot也可画散列图scatter. import numpy as np import matplotlib.pyplot as plt #fig = plt.figure ...

  4. 利用Tkinter和matplotlib两种方式画饼状图

    当我们学习python的时候,总会用到一些常用的模块,接下来我就详细讲解下利用两种不同的方式画饼状图.首先利用[Tkinter]中的canvas画布来画饼状图: from tkinter import ...

  5. 沉淀再出发:用python画各种图表

    沉淀再出发:用python画各种图表 一.前言 最近需要用python来做一些统计和画图,因此做一些笔记. 二.python画各种图表 2.1.使用turtle来画图 import turtle as ...

  6. 利用python画出动态高优先权优先调度

    之前写过一个文章. 利用python画出SJF调度图 动态高度优先权优先调度 动态优先权调度算法,以就绪队列中各个进程的优先权作为进程调度的依据.各个进程的优先权在创建进程时所赋予,随着进程的推进或其 ...

  7. 用Python画如此漂亮的专业插图 ?简直So easy!

    本文整理自知乎问答,仅用于学术分享,著作权归作者所有.如有侵权,请联系我删文处理.多多转发,多多学习! 方法一 强烈推荐 Python 的绘图模块 matplotlib: python plottin ...

  8. 用python画xy散点图

    import matplotlib.pyplot as plt plt.plot([1,2,3],[4,5,6],'ro') plt.show()#这个智障的编辑器 这样的话,就可以画一个散点图,图中 ...

  9. 四步轻松实现用Visio画UML类图

    本节和大家一起学习一下用Visio画UML类图的方法,主要有四个步骤,这里和大家分享一下,相信通过本节的学习,你对Visio画UML类图的步骤一定会有所了解. 用Visio画UML类图 对于画类图的工 ...

随机推荐

  1. docker镜像导入导出

    1.使用 save命令将 镜像保存为文件docker save -o  自定义文件名.tar  已存在的镜像名 2.使用load命令将镜像文件保存到本地仓库docker load -i 自定义文件名. ...

  2. seafile ubuntu 安装相关

    1,各种原因,需要安装 seafile,好,开始安装. 2,参考 https://github.com/haiwen/seafile-server-installer-cn 1,Ubuntu 16.0 ...

  3. opencart精简checkout购物流程

    最近在做一个商城项目,让外国朋友帮忙看看,他给我们一些建议了,其中他说Can You make more simple buying Button,3 step:Sign up :Shipping A ...

  4. JMeter-性能测试监控(解决.sh文件的启动)

    下载插件 https://jmeter-plugins.org/downloads/old/ 已安装了jmeter-plugins-manager,装的这个不知道生没生效.... 2.问题:启动就显示 ...

  5. LightGBM总结

    一.LightGBM介绍 LightGBM是一个梯度Boosting框架,使用基于决策树的学习算法.它可以说是分布式的,高效的,有以下优势: 1)更快的训练效率 2)低内存使用 3)更高的准确率 4) ...

  6. FB面经 Prepare: Count Unique Island

    数unique island, 比如 110000 110001 001101 101100 100000 总共两个unique岛,不是四个 方法可以是记录每次新的岛屿搜索的路径,left,right ...

  7. shiro认证登录实现

    准备工作: 在web.xml中配置shiro核心过滤器 在spring配置文件中提供核心过滤器运行所需要的辅助bean对象,在对象内注入安全管理器 拦截认证 配置三个url 拦截除了登录页面以及认证a ...

  8. C# 实现http不同方法的请求

    p{ text-align:center; } blockquote > p > span{ text-align:center; font-size: 18px; color: #ff0 ...

  9. 25 range打印100到0的连续整数

    使用range打印100,99,98,...0for i in range(100,-1,-1): print(i)

  10. 最简单的 react-router4 的安装和使用

    React-Router 的安装  npm install react-router React-Router提供了两个组件:Router和Route.下面看最简单的例子: src/Routes.js ...