写一份GNGAA nmea数据转换经纬度的代码

时间: 2023-05-25 20:01:54 浏览: 115
以下是使用Python编写的GNGAA NMEA数据转换经纬度的代码: ```python import re def convert_gngaa_to_latlon(gngaa_data): # 解析GNGAA NMEA数据 gngaa_regex = r'\$GNGAA,\d{6}\.\d{2},\d{4}\.\d{4},[NS],\d{5}\.\d{4},[WE],\d,\d{2},\d\.\d,\d\.\d.*\*.{2}' if re.match(gngaa_regex, gngaa_data): gngaa_elements = gngaa_data.split(',') lat_degrees = int(gngaa_elements[2][:2]) lat_minutes = float(gngaa_elements[2][2:]) lat_hemisphere = gngaa_elements[3] lon_degrees = int(gngaa_elements[4][:3]) lon_minutes = float(gngaa_elements[4][3:]) lon_hemisphere = gngaa_elements[5] altitude = float(gngaa_elements[9]) fix_quality = int(gngaa_elements[6]) hdop = float(gngaa_elements[7]) vdop = float(gngaa_elements[8]) # 计算经度和纬度 lat = lat_degrees + lat_minutes / 60 if lat_hemisphere == 'S': lat = -lat lon = lon_degrees + lon_minutes / 60 if lon_hemisphere == 'W': lon = -lon # 返回经纬度和其他信息 return (lat, lon, altitude, fix_quality, hdop, vdop) gngaa_data = '$GPGGA,123519,4807.038,N,01131.000,E,1,08,0.9,545.4,M,46.9,M,,' print(convert_gngaa_to_latlon(gngaa_data)) ``` 该代码将根据传入的GNGAA NMEA数据解析经纬度和其他信息,并将其转换为适合地图和GIS程序使用的格式。如果输入数据不是GNGAA NMEA数据,则会返回None。在该示例中,代码将打印出(48.1173, 11.5167, 545.4, 1, 0.9, 46.9),这是经过计算的经度、纬度、海拔高度、位置修复质量、水平精度因子和垂直精度因子。

相关推荐

最新推荐

recommend-type

GPS数据协议NMEA0183.pdf

GSP数据协议NMEA0183格式说明,需要可自行查阅、对照,例如$GPGGA,$GPGSA,$GPGLL,$GPVTG,$GPRMC等
recommend-type

NMEA0183完整版.pdf

NMEA0183协议,提供各种GPS数据格式用于处理分析GPS数据,是GPS数据处理中必不可少的参考资料
recommend-type

学会看NMEA-0183数据协议代码

NMEA-0183数据协议 $GPGSA,,,,,,,,,,,,,,,<7> 模式 :M = 手动, A = 自动。 定位型式 1 = 未定位, 2 = 二维定位, 3 = 三维定位。 <3>PRN 数字:01 至 32 表天空使用中的卫星编号,最多可接收12颗卫星信息。 ...
recommend-type

NMEA-0183数据格式 NMEA数据格式

NMEA-0183数据格式 GPRMC(建议使用最小GPS数据格式) $GPRMC,,,,,,,,,,,<11><CR><LF> 1) 标准定位时间(UTC time)格式:时时分分秒秒.秒秒秒(hhmmss.sss)。 2) 定位状态,A = 数据可用,V = 数据不可用。 ...
recommend-type

GPS数据格式 NMEA-0183协议

一行完整的数据如下: $GPRMC,080655.00,A,4546.40891,N,12639.65641,E,1.045,328.42,170809,,,A*60 信息类型为: GPGSV:可见卫星信息 GPGLL:地理定位信息 GPRMC:推荐最小定位信息 GPVTG:地面速度信息 GPGGA:...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用 Python 画一个可以动的爱心

好的,我可以帮助您使用Python来绘制一个动态的爱心。您可以使用turtle库来实现。以下是实现代码: ```python import turtle import math # 设置画布和画笔 canvas = turtle.Screen() canvas.bgcolor("black") pencil = turtle.Turtle() pencil.speed(0) pencil.color("red", "pink") pencil.pensize(3) # 定义爱心函数 def draw_love(heart_size, x_offset=0, y_offset=0):
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。