Python如何根据站点列表绘制站坐标全球分布图
发表于:2025-11-16 作者:千家信息网编辑
千家信息网最后更新 2025年11月16日,本篇内容主要讲解"Python如何根据站点列表绘制站坐标全球分布图",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"Python如何根据站点列表绘制站坐标全球
千家信息网最后更新 2025年11月16日Python如何根据站点列表绘制站坐标全球分布图
本篇内容主要讲解"Python如何根据站点列表绘制站坐标全球分布图",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"Python如何根据站点列表绘制站坐标全球分布图"吧!
根据站点列表绘制站坐标全球分布图
输入:站点列表文件、SNX全球站点坐标文件
站点列表文件示例(可手动创建):

结果输出:

代码:
# coding=utf-8# !/usr/bin/env python''' Program:plot_global_sitemap.py Function:根据站点列表绘制站坐标全球分布图 Author:LZ_CUMT Version:1.0 Date:2021/12/10 '''from math import pi, sqrt, atan, atan2, sin, cosimport matplotlib.pyplot as pltimport matplotlib as mplimport cartopy.crs as ccrsimport cartopy.feature as cfeaturefrom cartopy.mpl.ticker import LongitudeFormatter, LatitudeFormatter# xyz转换为llh(经纬度)def xyz2llh(ecef, site): aell = 6378137.0 fell = 1.0 / 298.257223563 deg = pi / 180 u = ecef[0] v = ecef[1] w = ecef[2] esq = 2*fell-fell*fell lat = 0 N = 0 if w == 0: lat = 0 else: lat0 = atan(w/(1-esq)*sqrt(u*u+v*v)) j = 0 delta = 10 ^ 6 limit = 0.000001/3600*deg while delta > limit: N = aell / sqrt(1 - esq * sin(lat0)*sin(lat0)) lat = atan((w / sqrt(u*u + v*v)) * (1 + (esq * N * sin(lat0) / w))) delta = abs(lat0 - lat) lat0 = lat j = j + 1 if j > 10: break long = atan2(v, u) h = (sqrt(u*u+v*v)/cos(lat))-N llh = [site, long * 180 / pi, lat * 180 / pi, h] return llh# 由站点文件获取站点列表存入sitelistdef getSite(listfile): sitelist = [] f = open(listfile) ln = f.readline() while ln: sitelist.append(ln[0:4].upper()) ln = f.readline() return sitelist# 根据站点名在snx文件中搜索XYZ坐标转化为经纬度并输出def getBLH_single(site,snxlines): xyz = [0, 0, 0] for ln in snxlines: if site in ln: if 'STAX ' in ln: xyz[0] = float(ln[47:68]) if 'STAY ' in ln: xyz[1] = float(ln[47:68]) if 'STAZ ' in ln: xyz[2] = float(ln[47:68]) blh = xyz2llh(xyz, site) if len(blh) != 4: print('[INFO] Sitecrd for', site, 'is not found in the snxfile') return blhdef getBLH(listfile, snxfile): siteBLH = [] sitelist = getSite(listfile) f = open(snxfile) lns = f.readlines() for site in sitelist: siteBLH.append(getBLH_single(site, lns)) return siteBLHdef plotsite(siteBLH): # mpl.rcParams['font.sans-serif'] = ['Helvetical'] mpl.rcParams['axes.unicode_minus'] = False mpl.rc('xtick', labelsize=9) mpl.rc('ytick', labelsize=9) mpl.rcParams['xtick.direction'] = 'in' mpl.rcParams['ytick.direction'] = 'in' fig = plt.figure(figsize=(14, 7)) ax = plt.axes(projection=ccrs.PlateCarree(central_longitude=150)) ax.set_extent([-180, 180, -90, 90], crs=ccrs.PlateCarree()) ax.set_xticks([0, 60, 120, 180, 240, 300, 360], crs=ccrs.PlateCarree()) ax.set_yticks([-90, -60, -30, 0, 30, 60, 90], crs=ccrs.PlateCarree()) ax.add_feature(cfeature.LAND) ax.add_feature(cfeature.OCEAN) ax.add_feature(cfeature.COASTLINE, linewidth=0.1) for site in siteBLH: ax.plot(site[1], site[2], 'o', color='r', mec='k', mew=0.5, transform=ccrs.Geodetic(), ms=13.0) plt.text(site[1] + 1.5, site[2] + 1.5, site[0], transform=ccrs.Geodetic(),fontsize='x-large') # 添加站名标注 plt.xticks(fontsize='x-large') plt.yticks(fontsize='x-large') lon_formatter = LongitudeFormatter(zero_direction_label=True) lat_formatter = LatitudeFormatter() ax.xaxis.set_major_formatter(lon_formatter) ax.yaxis.set_major_formatter(lat_formatter) fig.savefig('global_sitemap.png', bbox_inches='tight', dpi=400) plt.show()if __name__ == '__main__': listfile = r'site.info' # 输入要画的站点列表文件 snxfile = r'igs21P2177.snx' # 输入IGS站坐标文件 siteBLH = getBLH(listfile, snxfile) # 获取所有站点的经纬度 plotsite(siteBLH) # 画图 print('[INFO] Plot complete!') # 完成到此,相信大家对"Python如何根据站点列表绘制站坐标全球分布图"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
站点
坐标
文件
全球
分布图
经纬
经纬度
输入
内容
学习
输出
实用
更深
代码
兴趣
实用性
实际
手动
操作简单
方法
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
中国移动域名解析服务器故障
obs推流服务器什么意思
艺术照模板软件开发
公园网络技术与规划
智慧工地软件开发方案
上饶网络安全学院
软件开发工程师有哪几个岗位
ftp服务器怎么退出登录
甘肃日报林铎在网络安全
江苏采木工业互联网科技
我国应对网络安全基本方略
四川大学网络安全复试科目
达梦数据库更换正式key
苏州推广机器人rpa软件开发
泰康人寿软件开发怎么样
核电软件开发薪资待遇
网络安全信息领导小组组长
基于安卓软件开发的论文
公安防范化解网络安全风险
信息网络技术实验报告
大学关于软件开发
广州家政软件开发报价
数据库中设置三位整数和两位小数
网络安全工程师学费价格表
华硕服务器开不显示qcode
固原软件开发推荐
网络安全教育宣传知识
软件开发如何做外包
苏州幻塔网络技术有限公司
大姚县网络安全宣传