Java 正则表达式从GPGGA字符串中提取Lat和Long
例如,我有一个GPS记录器输出GPGGA字符串Java 正则表达式从GPGGA字符串中提取Lat和Long,java,regex,Java,Regex,例如,我有一个GPS记录器输出GPGGA字符串 $GPGGA,1714.03723.465874,北,12202.26954,西,2,6,1.2,18.893,米,-25.669,米,2.00031*4F 字符串以逗号分隔。在Java中,我试图提取位置信息。有人能帮我弄一下所需的正则表达式吗 第二个和第三个逗号之间的3723.465874 N在第三个和第四个逗号之间 12202.26954在第4和第5个逗号之间 W在第5和第6个逗号之间 或者,也许只是一个例子,所以我可以推断出其他的例子 谢
$GPGGA,1714.03723.465874,北,12202.26954,西,2,6,1.2,18.893,米,-25.669,米,2.00031*4F
字符串以逗号分隔。在Java中,我试图提取位置信息。有人能帮我弄一下所需的正则表达式吗
- 第二个和第三个逗号之间的
3723.465874
在第三个和第四个逗号之间N
在第4和第5个逗号之间12202.26954
在第5和第6个逗号之间W
谢谢。只需在逗号上拆分字符串,然后从生成的字符串数组中获取相应的部分
String gpgga =
"$GPGGA,1714.0,3723.465874,N,12202.26954,W,2,6,1.2,18.893,M,-25.669,M,2.0,0031*4F"
String[] parts = gpgga.split(",");
String latitude = parts[2];
String nb = parts[3];
String longitude = parts[4];
String ew = parts[5];
因为您有一个干净的分隔符,所以可以使用
String.split
,如下所示:
String data = "$GPGGA,1714.0,3723.465874,N,12202.26954,W,2,6,1.2,18.893,M,-25.669,M,2.0,0031*4F";
String[] parts = data.split(",");
String p2 = parts[2]; // 3723.465874
String p3 = parts[3]; // N
String p4 = parts[4]; // 12202.26954
String p5 = parts[5]; // W
来自:
包es.agroguia.model;
导入java.util.HashMap;
导入java.util.Map;
公共类NMEA{
类GPSPosition{
公共浮动时间=0.0f;
公共浮动lat=0.0f;
公共浮子lon=0.0f;
公共布尔固定=假;
公共int质量=0;
公共浮点数dir=0.0f;
公众浮标高度=0.0f;
公共浮动速度=0.0f;
public void updatefix(){
固定=质量>0;
}
公共字符串toString(){
返回字符串格式(“位置:纬度:%f,经度:%f,时间:%f,Q:%d,方向:%f,高度:%f,标高:%f”,纬度,经度,时间,质量,方向,高度,速度);
}
}
GPSPosition位置=新的GPSPosition();
私有静态最终映射语句解析器=new HashMap();
公共NMEA(){
put(“GPGGA”,新的GPGGA());
put(“GPGGL”,新的GPGGL());
put(“GPRMC”,新的GPRMC());
put(“GPRMZ”,新的GPRMZ());
//只有真正好的GPS设备才有这句话,但是。。。
put(“GPVTG”,新的GPVTG());
}
公共GPSPosition解析(字符串行){
if(第行开始时带($)){
字符串nmea=行。子字符串(1);
字符串[]标记=nmea.split(“,”);
字符串类型=令牌[0];
//TODO校验crc
if(sentenceParsers.containsKey(类型)){
get(type).parse(tokens,position);
}
position.updatefix();
}
返回位置;
}
}
接口语句分析器{
公共布尔解析(字符串[]标记,GPSPosition位置);
}
//乌提尔斯
静态浮点Latitude2Decimal(字符串lat,字符串NS){
float-med=float.parseFloat(横向子串(2))/60.0f;
med+=Float.parseFloat(lat.substring(0,2));
如果(不适用,以“S”开头){
med=-med;
}
返回医学院;
}
静态浮点longitudecimal(字符串lon、字符串WE){
float-med=float.parseFloat(lon.substring(3))/60.0f;
med+=Float.parseFloat(lon.substring(0,3));
如果(我们以“W”开头){
med=-med;
}
返回医学院;
}
//解析器
类GPGGA实现句子分析器{
公共布尔解析(字符串[]标记,GPSPosition位置){
position.time=Float.parseFloat(标记[1]);
position.lat=Latitude2Decimal(标记[2],标记[3]);
position.lon=longitude2十进制(标记[4],标记[5]);
position.quality=Integer.parseInt(标记[6]);
position.altime=Float.parseFloat(标记[9]);
返回true;
}
}
}
肯定是比我提出的方法更好的解决方案,也是我Java知识的重要补充。
package es.agroguia.model;
import java.util.HashMap;
import java.util.Map;
public class NMEA {
class GPSPosition {
public float time = 0.0f;
public float lat = 0.0f;
public float lon = 0.0f;
public boolean fixed = false;
public int quality = 0;
public float dir = 0.0f;
public float altitude = 0.0f;
public float velocity = 0.0f;
public void updatefix() {
fixed = quality > 0;
}
public String toString() {
return String.format("POSITION: lat: %f, lon: %f, time: %f, Q: %d, dir: %f, alt: %f, vel: %f", lat, lon, time, quality, dir, altitude, velocity);
}
}
GPSPosition position = new GPSPosition();
private static final Map<String, SentenceParser> sentenceParsers = new HashMap<String, SentenceParser>();
public NMEA() {
sentenceParsers.put("GPGGA", new GPGGA());
sentenceParsers.put("GPGGL", new GPGGL());
sentenceParsers.put("GPRMC", new GPRMC());
sentenceParsers.put("GPRMZ", new GPRMZ());
//only really good GPS devices have this sentence but ...
sentenceParsers.put("GPVTG", new GPVTG());
}
public GPSPosition parse(String line) {
if(line.startsWith("$")) {
String nmea = line.substring(1);
String[] tokens = nmea.split(",");
String type = tokens[0];
//TODO check crc
if(sentenceParsers.containsKey(type)) {
sentenceParsers.get(type).parse(tokens, position);
}
position.updatefix();
}
return position;
}
}
interface SentenceParser {
public boolean parse(String [] tokens, GPSPosition position);
}
// utils
static float Latitude2Decimal(String lat, String NS) {
float med = Float.parseFloat(lat.substring(2))/60.0f;
med += Float.parseFloat(lat.substring(0, 2));
if(NS.startsWith("S")) {
med = -med;
}
return med;
}
static float Longitude2Decimal(String lon, String WE) {
float med = Float.parseFloat(lon.substring(3))/60.0f;
med += Float.parseFloat(lon.substring(0, 3));
if(WE.startsWith("W")) {
med = -med;
}
return med;
}
// parsers
class GPGGA implements SentenceParser {
public boolean parse(String [] tokens, GPSPosition position) {
position.time = Float.parseFloat(tokens[1]);
position.lat = Latitude2Decimal(tokens[2], tokens[3]);
position.lon = Longitude2Decimal(tokens[4], tokens[5]);
position.quality = Integer.parseInt(tokens[6]);
position.altitude = Float.parseFloat(tokens[9]);
return true;
}
}
}
String input = "$GPGGA,1714.0,3723.465874,N,12202.26954,W,2,6,1.2,18.893,M,-25.669,M,2.0,0031*4F";
Pattern pattern = Pattern.compile("^\\$GPGGA,[\\d\\.]*,([\\d\\.]+),([NS]),([\\d\\.]+),([EW]),.*");
Matcher matcher = pattern.matcher(input);
if (matcher.matches()) {
for(int i=0; i <= matcher.groupCount(); i++) {
System.out.println("Group " + i + " = " + matcher.group(i));
}
} else {
throw new IllegalArgumentException("Invalid input!");
}
Group 0 = $GPGGA,1714.0,3723.465874,N,12202.26954,W,2,6,1.2,18.893,M,-25.669,M,2.0,0031*4F
Group 1 = 3723.465874
Group 2 = N
Group 3 = 12202.26954
Group 4 = W