Kurt Schwehr有一个很好的github存储库,他在沿海和海洋测绘中心工作(例如,跟踪鲸鱼活动)。在那里,您将找到一个解码器和文档,以了解nmea消息(大多数链接由@ianmayo和@GID Dev提及)。这是在LINUX
和下运行的一个小方法python 2.7
。
要运行某些代码,您需要git
一个C++
编译器python setup environment
,cmake
。从下载数据
$ cd YOUR_BUILD_PATH
$ git clone https://github.com/schwehr/libais.git
并按照github页面上/上的安装说明进行操作
$ cd YOUR_BUILD_PATH/libais
$ cmake . # to bulid the Makefile
$ make # to build the libais C++
$ python setup.py build # to build the python stuff
$ sudo python setup.py install # to deploy it
毕竟,您应该在python
环境中拥有这些库。
$ ls /usr/local/lib/python2.7/dist-packages/
easy-install.pth libais-0.16-py2.7-linux-x86_64.egg
$ ls /usr/local/lib/python2.7/dist-packages/libais-0.16-py2.7-linux-x86_64.egg
ais _ais.py _ais.pyc _ais.so EGG-INFO test
这是一个脚本中的一些快速而肮脏的代码,该脚本被称为test-ais.py
以获取类似head
&tail
behavoir 的unix 。我json
用作“明文漂亮的打印机”。
#!/usr/bin/python
# To supress the warning ...could be done better
# FutureWarning: The stream module is deprecated and will be removed in 1.0
# https://github.com/schwehr/libais/blob/master/ais/stream/__init__.py
# coded in in __init__.py line 10-14
import warnings
warnings.filterwarnings("ignore")
# import json module for pretty print
import json
# import ais.stream module to decode
# a ais binary nmea message to json
import ais.stream
# import sys module to read stuff from
# standard input STDIN
import sys
# decode a file or somthing form the STDIN
f = open(sys.argv[1]) if len(sys.argv) > 1 else sys.stdin
# Iterate over the messages
for msg in ais.stream.decode(f):
# make a json pretty print for each message
print json.dumps(msg, indent=4, sort_keys=True)
# EOF
假设nmea-samples
文件在data
目录中,则可以过滤出要显示的行cat
,head
然后tail
...
$ tail -1 data/nmea-sample | ./test-ais.py
{
"day": 14,
"fix_type": 1,
"hour": 11,
"id": 4,
"minute": 33,
"mmsi": 2320717,
"month": 3,
"position_accuracy": 0,
"raim": false,
"repeat_indicator": 3,
"second": 30,
"slot_offset": 2250,
"slot_timeout": 0,
"spare": 0,
"sync_state": 0,
"transmission_ctl": 0,
"x": -5.782454967498779,
"y": 57.842193603515625,
"year": 2012
}
从json代码开始,进一步格式化和存储内容应该很容易。