如何从特定网站提取HTML表到外部HTML文件?

时间:2019-06-05 18:46:18

标签: java html parsing

要求我编写一个应用程序,该应用程序将从给定的URL https://www.ote-cr.cz/en/statistics/electricity-imbalances-1中仅下载主表(标记为report_table)并将其存储在单独的HTML文件中。

我设法下载了表格的内容,但是,我无法按照要求正确设置样式。这是我的代码:

    Document doc = Jsoup.connect(url).get();

    System.out.println(doc);
    Element tableElement = doc.select("table.table.report_table").first();

    Elements tableHeaderElements = tableElement.select("thead tr th");
    System.out.println("headers");

    for (int i = 0; i < tableHeaderElements.size(); i++) {
        System.out.println(tableHeaderElements.get(i).text());
        writer.append(tableHeaderElements.get(i).text());

        if (i != tableHeaderElements.size() - 1) {
            writer.append(',');
        }
    }
    writer.append('\n');
    System.out.println();

    Elements tableRowElements = tableElement.select(":not(thead) tr");

    for (int i = 0; i < tableRowElements.size(); i++) {
        Element row = tableRowElements.get(i);
        System.out.println("row");
        Elements rowItems = row.select("td");
        for (int j = 0; j < rowItems.size(); j++) {
            System.out.println(rowItems.get(j).text());
            writer.append(rowItems.get(j).text());

            if (j != rowItems.size() - 1) {
                writer.append(' ');
            }
        }
        writer.append('\n');
    }

    writer.close();
}

为了在单独的HTML中获得样式正确的表,我应该在代码中添加些什么?

1 个答案:

答案 0 :(得分:0)

这将提取html表(不包含CSS)并将其保存到文件中

public class Parser {
    public void parseAndWrite() {

        Document doc;
        try {
            doc = Jsoup.connect(" https://www.ote-cr.cz/en/statistics/electricity-imbalances-1").get();

            PrintWriter writer = new PrintWriter(new File("out.html"));
            System.out.println(doc);
            Element tableElement = doc.select("div.bigtable").first();

            writer.write(tableElement.toString());

            writer.close();
        } catch (IOException e) {
            // LOG may be?
        }
    }

希望这会有所帮助