Java 缓冲阅读器文本文件解析

发布于 2024-08-20 18:26:14 字数 3202 浏览 5 评论 0原文

我真的很难解析文本文件。我有一个采用以下格式的文本文件

ID
Float Float 
Float Float
....   // variable number of floats
END
ID
Float Float 
Float Float
....   
END

等,但是 ID 可以表示两个值之一,0 表示它是一个新字段,或 -1 表示它与最后一个新字段相关。相关字段可以重复的次数是无限的。这就是问题发生的地方。

因为我在库中有一个方法,它接受新浮点数的 ArrayList,然后接受相关浮点数的 ArrayList 的 ArrayList。

当我尝试为此编写逻辑时,我只会越来越深入地嵌入 while 循环。

我真的很感激任何关于我应该如何解决这个问题的建议。提前致谢。

这是我到目前为止的代码。

BufferedReader br = new BufferedReader(new FileReader(buildingsFile));

        String[] line = br.readLine().trim().split("    ");
        boolean original = true;

        while(true)
        {
            if(line[0].equals("END"))
                break;

            startCoordinate = new Coordinate(Double.parseDouble(line[0]), Double.parseDouble(line[1]));

            while(true)
            {
                line = br.readLine().trim().split("    ");

                if(!line[0].equals("END") && original == true)
                    polypoints.add(new Coordinate(Double.parseDouble(line[0]), Double.parseDouble(line[1])));
                else if(!line[0].equals("END") && original == false)
                    cutout.add(new Coordinate(Double.parseDouble(line[0]), Double.parseDouble(line[1])));
                else if(line[0].equals("END") && original == false)
                {
                    cutouts.add(cutout);
                    cutout.clear();
                }
                else if(line[0].equals("-99999"))
                    original = false;
                else if(line[0].equals("0"))
                    break;
            }

            buildingDB.addBuilding(mapName, startCoord, polypoints, cutouts);
        }

新代码

        int i = 0;

        BufferedReader br = new BufferedReader(new FileReader(buildingsFile));

        String[] line;

        while(true)
        {
            line = br.readLine().trim().split("    ");

            if(line[0].equals("END"))
                break;

            polygons.add(new Polygon(line));

            while(true)
            {
                line = br.readLine().trim().split("    ");

                if(line[0].equals("END"))
                    break;
                polygons.get(i).addCoord(new Coordinate(Double.parseDouble(line[0]), Double.parseDouble(line[1])));
            }



            i++;
        }
        System.out.println(polygons.size());


        int j = 0;
        for(i = 0; i< polygons.size(); i++)
        {
            Building newBuilding = new Building();

            if(polygons.get(i).isNew == true)
            {
                newBuilding = new Building();
                newBuilding.startCoord = new Coordinate(polygons.get(i).x, polygons.get(i).y);
            }

            while(polygons.get(i).isNew == false)
                newBuilding.cutouts.add(polygons.get(i).coords);

            buildings.add(newBuilding);
        }

        for(i = 0; i<buildings.size(); i++)
        {
            System.out.println(i);
            buildingDB.addBuilding(mapName, buildings.get(i).startCoord, buildings.get(i).polypoint, buildings.get(i).cutouts);
        }

I am really struggling with parsing a text file. I have a text file which is in the following format

ID
Float Float 
Float Float
....   // variable number of floats
END
ID
Float Float 
Float Float
....   
END

etc However the ID can represent one of two values, 0 which means it is a new field, or -1 which means it is related to the last new field. The number of times a related field can repeat it self is unlimited. Which is where the problem is occurring.

As I have a method in a library which takes an ArrayList of the new Floats, then an ArrayList of an ArrayList of the related floats.

When I try and code the logic for this I just keep getting deeper and deeper embedded while loops.

I would really appreciate any suggestions as to how I should go about this. Thanks in advance.

Here is the code I have so far.

BufferedReader br = new BufferedReader(new FileReader(buildingsFile));

        String[] line = br.readLine().trim().split("    ");
        boolean original = true;

        while(true)
        {
            if(line[0].equals("END"))
                break;

            startCoordinate = new Coordinate(Double.parseDouble(line[0]), Double.parseDouble(line[1]));

            while(true)
            {
                line = br.readLine().trim().split("    ");

                if(!line[0].equals("END") && original == true)
                    polypoints.add(new Coordinate(Double.parseDouble(line[0]), Double.parseDouble(line[1])));
                else if(!line[0].equals("END") && original == false)
                    cutout.add(new Coordinate(Double.parseDouble(line[0]), Double.parseDouble(line[1])));
                else if(line[0].equals("END") && original == false)
                {
                    cutouts.add(cutout);
                    cutout.clear();
                }
                else if(line[0].equals("-99999"))
                    original = false;
                else if(line[0].equals("0"))
                    break;
            }

            buildingDB.addBuilding(mapName, startCoord, polypoints, cutouts);
        }

New Code

        int i = 0;

        BufferedReader br = new BufferedReader(new FileReader(buildingsFile));

        String[] line;

        while(true)
        {
            line = br.readLine().trim().split("    ");

            if(line[0].equals("END"))
                break;

            polygons.add(new Polygon(line));

            while(true)
            {
                line = br.readLine().trim().split("    ");

                if(line[0].equals("END"))
                    break;
                polygons.get(i).addCoord(new Coordinate(Double.parseDouble(line[0]), Double.parseDouble(line[1])));
            }



            i++;
        }
        System.out.println(polygons.size());


        int j = 0;
        for(i = 0; i< polygons.size(); i++)
        {
            Building newBuilding = new Building();

            if(polygons.get(i).isNew == true)
            {
                newBuilding = new Building();
                newBuilding.startCoord = new Coordinate(polygons.get(i).x, polygons.get(i).y);
            }

            while(polygons.get(i).isNew == false)
                newBuilding.cutouts.add(polygons.get(i).coords);

            buildings.add(newBuilding);
        }

        for(i = 0; i<buildings.size(); i++)
        {
            System.out.println(i);
            buildingDB.addBuilding(mapName, buildings.get(i).startCoord, buildings.get(i).polypoint, buildings.get(i).cutouts);
        }

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

隱形的亼 2024-08-27 18:26:14

也许您应该使用新的浮动和相关浮动的地图..如果得到您的问题,它应该有所帮助..示例:

HashMap hm = new HashMap();
hm.put("Rohit", new Double(3434.34));

Maybe you should use map for new floats and related floats..if got your question it should help..example:

HashMap hm = new HashMap();
hm.put("Rohit", new Double(3434.34));
甜心 2024-08-27 18:26:14

我假设“字段”意味着一个 ID 和可变数量的坐标(浮点对),从您的代码来看,它实际上代表一个多边形。

我首先加载所有多边形,每个多边形都加载到一个单独的 Polygon 对象中:

class Polygon {
    boolean isNew;
    List<Coordinate> coordinates;
}

并将多边形存储在另一个列表中。然后在第二遍中遍历所有多边形,根据它们的 ID 将它们分组为类似的东西,

class Building {
    Polygon polygon;
    List<Polygon> cutouts;
}

我认为这编码起来相当简单。

OTOH 如果文件中有大量数据,并且/或者您更喜欢一点一点地处理读取的数据,您可以简单地读取一个多边形及其所有关联的切口,直到找到下一个多边形(ID 为 0),此时,您可以简单地将到目前为止读取的内容传递到构建数据库并开始读取下一个多边形。

I assume that a "field" means an ID and a variable number of coordinates (pairs of floats), that, judging from your code, represents a polygon in fact.

I would first load all the polygons, each into a separate Polygon object:

class Polygon {
    boolean isNew;
    List<Coordinate> coordinates;
}

and store the polygons in another list. Then in a 2nd pass go through all the polygons to group them according to their IDs into something like

class Building {
    Polygon polygon;
    List<Polygon> cutouts;
}

I think this would be fairly simple to code.

OTOH if you have a huge amount of data in the file, and/or you prefer processing the read data little by little, you could simply read a polygon and all its associated cutouts, until you find the next polygon (ID of 0), at which point you could simply pass the stuff read so far to the building DB and start reading the next polygon.

总以为 2024-08-27 18:26:14

您可以在这里尝试使用 ANTLR,语法定义了您期望的文本格式,然后您可以将内容包装在 Java 对象中。 * 和 + 通配符将解决 while 和 for 的复杂性。它非常简单易用,你不必构造 AST,你可以直接从 java 对象中获取解析的内容。但唯一的开销是您必须将 ANTLR.jar 添加到您的路径中。

You can try using ANTLR here, The Grammar defines the format of the text you are expecting and then you can wrap the contents in a Java object. The * and + Wildcards will resolve the complexity of while and for. Its very simple and easy to use, you dont have to construct AST you can take the parsed content from java objects directly. But the only overhead is you have to add the ANTLR.jar to your path.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文