第十二课python来写串口助手-gps数据解析(一)
off999 2024-09-27 13:56 43 浏览 0 评论
1、串口程序的基本功能我们已经完成了,我们来完成一个串口解析的功能,GPS的定位解析是一个比较常用的功能,这节课我们来解析GPS数据。
2、GPS数据格式为NEMA-0183数据格式,一般判断是否已经定位都是选择推荐定位信息也就是$GPRMC,,我们来看下一条GPS数据的内容:
$GPRMC,121252.000,A,3958.3032,N,11629.6046,E,15.15,359.95,070306,,,A*54
根据推荐定位信息的定义:
$GPRMC,1,2,3,4,5,6,7,8,910,11,12*hh<CR><LF>
1)UTC时间,hhmmss(时分秒)格式
2) 定位状态,A=有效定位,V=无效定位
3) 纬度
4) N(北半球)或S(南半球)
5) 经度
6) E(东经)或W(西经)
7) 地面速率
12) 模式指示(A=自主定位,D=差分,E=估算,N=数据无效)
我们所需要的数据已经列出,我们实际的使用的北京时间是等于utc时间+8小时。
我们来看下GPS数据的格式,以$符号为开头,以\r\n来结尾,所以来写一个基本的语句判断函数。
串口读到的数据是bytes,我们在pythonwork目录新增一个文件gps.py,如下所示:
新增如下代码:
#coding:utf-8
class gps():
def __init__(self):
self.realdata=b''
self.fb=False
def Get_gps_data(self,sdata):
sl=[]
for e in sdata:
if e==0x24 and self.fb==False:
self.fb=True
if self.fb:
self.realdata+=bytes([e])
if e==0x0a and self.fb:
data=self.realdata.decode('utf-8','replace')
sl.append(data)
self.fb=False
self.realdata=b''
print(sl)
return sl
我们来调用验证一下:
g=gps()
sdata="$GPRMC,121252.000,A,3958.3032,N,11629.6046,E,15.15,359.95,070306,,,A*54\r\n".encode('utf-8')
g.Get_gps_data(sdata)
运行一下:
运行结果能判断以0x24开头以及0xa结尾的数据格式,当然在实际的串口数据读取中,有可能会出现0x0d 0x0a丢失的情况,所以我们增加一种情况的判定:
def Get_gps_data(self,sdata):
sl=[]
for e in sdata:
if e==0x24 and self.fb==False:
self.fb=True
self.realdata+=bytes([e])
if self.fb and e==0x0a:
self.realdata+=bytes([e])
data=self.realdata.decode('utf-8','replace')
sl.append(data)
self.fb=False
self.realdata=b''
elif e!=0x24 and self.fb:
self.realdata+=bytes([e])
elif e==0x24 and self.fb and len(self.realdata)>5:
data=self.realdata.decode('utf-8','replace')
sl.append(data)
self.realdata=b''
self.realdata+=bytes([e])
print(sl)
return sl
输入测试代码:
g=gps()
sdata="$GPRMC,121252.000,A,3958.3032,N,11629.6046,E,15.15,359.95,070306,,,A*54$GPRMC,121252.000,A,3958.3032,N,11629.6046,E,15.15,359.95,070306,,,A*54\r\n".encode('utf-8')
g.Get_gps_data(sdata)
运行一下:
3、校验GPS数据是否正确,以上面的函数确实可以将GPS数据判断出来,但是非GPS数据只要满足格式的也会筛选出来,所以我们需要校验GPS的数据格式是否正确,我们查看NEMA数据信息,在数据段*号后面的为校验值:
$GPRMC,121252.000,A,3958.3032,N,11629.6046,E,15.15,359.95,070306,,,A*54
比如上面数据,54就是从$后面的数据,*前面的数据通过异或校验而得到的数据值,增加函数如下:
def CheckGpsBuff(self,buff):
buff=buff.replace("\r","").replace("\n","")
isok = False
if len(buff)==(buff.find('*')+2):
pass
else:
crc=0
for ch in buff:
if ch=='$':
pass
elif ch=='*':
break
else:
if crc==0:
crc=ord(ch)
else:
crc=crc^ord(ch)
try:
if buff.find('*')+3==len(buff):
length=buff.find('*')
s=buff[length+1]+buff[length+2]
scode=(str(hex(crc))[2:]).upper()
if len(scode)==2:
pass
else:
scode="0"+scode
if s==scode:
isok=True
except Exception as e:
print("gpsErr:",str(e))
return isok
调用代码:
g=gps()
sdata="$GPRMC,121252.000,A,3958.3032,N,11629.6046,E,15.15,359.95,070306,,,A*54$GPRMC,121252.000,A,3958.3032,N,11629.6046,E,15.15,359.95,070306,,,A*54\r\n".encode('utf-8')
sl=g.Get_gps_data(sdata)
for e in sl:
print(g.CheckGpsBuff(e))
运行一下:
我们今天已经实现了GPS数据的格式校验,明天完成数据解析。
相关推荐
- 如何桥接无线路由器并设置上网
-
1、登录副路由器管理界面操作电脑连接到副路由器的LAN口或无线信号(默认为TP-LINK_XXXX),打开浏览器,清空地址栏并输入tplogin.cn或192.168.1.1,设置不少于6位数的登录密...
- 电脑配置搭配(电脑配置搭配表)
-
电脑配置搭配需要考虑多个组件,包括CPU、主板、显卡、内存、硬盘、电源以及散热器等。以下是一些建议和指南:CPU选择:CPU是电脑的心脏,决定了电脑的整体性能。选择CPU时需要考虑核心数、主频、线程数...
- windows7安装步骤简述(win7的安装)
-
运行温度时期的电脑怎么组装?官方已经给出了相关配置:处理器(cpu)最好是主频1GHZ以上,32位或64位处理器,不过目前的处理器几乎都是64位的了,一般双核处理器都在1GHZ以上。 也就是说目前绝...
- 电脑删除的数据怎么恢复(电脑删除数据怎么恢复原状)
-
步骤一:打开电脑上已经装好的Superrecovery软件,直接进入到“向导模式”。首先,大家需要做的就是选择文件所在的位置,例如:需要恢复的数据是在移动存储设备上(如:U盘、SD卡等),直接选择设备...
- 删除数据恢复(删除数据恢复出厂设置)
-
1.在手机上下载手机数据恢复精灵,进入软件之后,选择微信恢复。2.点击开始恢复,选择需要恢复的联系人,等待一会儿,就能看到恢复好的聊天记录。3.可以安装打开互盾安卓恢复大师,手机数据线连接手机后,点击...
- 复制粘贴不了怎么解决(电脑不能复制粘贴了怎么处理)
-
1、查看手机输入法的剪贴板选项,是否有复制的文本,如果有就直接点击就可以直接输入了。2、复制后,长按不出来粘贴键的时候,需要把应用程序关闭掉重新开,重新复制粘贴,或者尝试重启手机。3、可以尝试重新复制...
- u盘被写保护去除步骤(u盘的被写保护怎么解除)
-
U盘被写保护通常是因为存储器故障、病毒感染、文件系统损坏等原因导致的,但可以通过以下几种方法进行解除:1.检查U盘开关:一些U盘可能会有物理上的写保护开关,将其关闭即可解除写保护。2.使用命令行清...
- 电脑蓝屏怎么用u盘重装系统(电脑蓝屏重装系统教程u盘)
-
U盘装系统步骤:1.制作U盘启动盘。这里推荐U启动U盘启动盘制作工具,在网上一搜便是。2.U盘启动盘做好了,我们还需要一个GHOST文件,可以从网上下载一个ghost版的XP/WIN7/WIN8系统,...
-
- erp管理软件(erp管理软件免费版)
-
用友的ERP应该说从3万-3000都有ERP的价格随着企业的规模不同,价格也是不一样的。因为企业规模不同产生的效果也是不一样的,所以用友的产品分T1/T3/T6/U8/U9/NC3万小企业做个财务业务一体化还是勉强可以做的。只...
-
2025-11-11 09:03 off999
- 笔记本启动黑屏怎么回事(笔记本启动黑屏没反应)
-
笔记本开机后黑屏最常遇到的一种情况:因随便点击垃圾网站而导致电脑中脑或受到木马的侵袭,致使电脑系统瘫痪,解决的办法就是重装电脑系统,装好系统后安装查毒软件,定期对电脑进行杀毒全盘扫描,然后平时尽量不要...
- win7系统怎么开wifi热点(win7如何开wifi热点)
-
1、首先确认你的无线网卡开启。在开始菜单中依次找到“所有程序”--“附件”--“命令提示符”,右键“以管理员身份运行”; 2、在“命令提示符”里输入“netshwlans...
- 无线路由桥接设置方法(无线路由器无线桥接设置)
-
1、首先在电脑上输入并登录第一台路由器的IP地址。2、进入路由器管理界面之后,点击“无线设置”,然后点击基本设置中设置“SSID号”,接着点击“信道”,然后设置固定信号道。3、返回无线设置菜单栏,选择...
- win10企业版激活命令(win10企业版cmd激活命令)
-
关于这个问题,Windows10企业版可以通过以下方法进行激活:1.使用企业版密钥激活:如果你已经有了Windows10企业版的密钥,可以在“设置”中的“更新和安全”中选择“激活”来输入密钥进行...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
慕ke 前端工程师2024「完整」
-
失业程序员复习python笔记——条件与循环
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
