1

我使用 htmlunit 从网页中抓取图像。我是htmlunit的初学者。我编码,但不知道如何获取图像。下面是我的代码。

import java.io.*;
import java.net.URL;
import com.gargoylesoftware.htmlunit.BrowserVersion;
import com.gargoylesoftware.htmlunit.WebClient;
import com.gargoylesoftware.htmlunit.html.HtmlPage;

public class urlscrap {

    public static void main(String[] args) throws Exception 
    {

        //WebClient webClient = new WebClient(Opera);
        WebClient webClient = new WebClient();
        HtmlPage currentPage = (HtmlPage) webClient.getPage(new URL("http://www.google.com"));

        System.out.println(currentPage.asText());
        //webClient.closeAllWindows();      

    }
}
4

3 回答 3

5

这对你有用吗??

import java.net.URL;
import java.util.List;

import com.gargoylesoftware.htmlunit.WebClient;
import com.gargoylesoftware.htmlunit.html.HtmlImage;
import com.gargoylesoftware.htmlunit.html.HtmlPage;

public class urlscrap {

    public static void main(String[] args) throws Exception 
    {

        //WebClient webClient = new WebClient(Opera);
        WebClient webClient = new WebClient();
        HtmlPage currentPage = (HtmlPage) webClient.getPage(new URL("http://www.google.com"));
      //get list of all divs
        final List<?> images = currentPage.getByXPath("//img");
        for (Object imageObject : images) {
            HtmlImage image = (HtmlImage) imageObject;
            System.out.println(image.getSrcAttribute());
        }
        //webClient.closeAllWindows();      
    }
}
于 2012-04-11T03:51:33.980 回答
0

看起来您正在获取页面的文本,这确实是第一步。你有什么问题?您在查找页面中引用的所有图像时遇到问题吗?我建议查找如何在 Java 中进行 DOM 解析,并使用它从页面中提取所有 img 标签。

于 2012-04-11T03:11:02.377 回答
0

如果你不介意切换语言,那么我会推荐 Python 的scrapy。这是迄今为止我用来抓取 Web 内容(包括图像)的最佳框架(它甚至可以自动为您创建缩略图)。就个人而言,我不会将 java 用于此类任务。

于 2012-04-11T03:26:23.590 回答