Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/regex/20.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 正则表达式从GPGGA字符串中提取Lat和Long_Java_Regex - Fatal编程技术网

Java 正则表达式从GPGGA字符串中提取Lat和Long

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个逗号之间 或者,也许只是一个例子,所以我可以推断出其他的例子 谢

例如,我有一个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个逗号之间
或者,也许只是一个例子,所以我可以推断出其他的例子


谢谢。

只需在逗号上拆分字符串,然后从生成的字符串数组中获取相应的部分

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