3

如何在 Java 项目中使用 Goose?我测试了boilerpipe和goose的在线版本,最后一个更好,但现在它是在Scala中开发的。

我搜索了以前版本的jar,但找不到它(api都没有)。我尝试的最后一个 .jar 是:goose-2.1.22。我将它导入我的 Ecpise 项目并尝试使用以下代码:

String url = "http://www.cnn.com/2010/POLITICS/08/13/democrats.social.security/index.html";
Goose goose = new Goose(new Configuration());
Article article = goose.extractContent(url);
System.out.println(article.cleanedArticleText());

但我得到这个错误:

Exception in thread "main" java.lang.NoClassDefFoundError: scala/ScalaObject
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:615)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:283)
    at java.net.URLClassLoader.access$000(URLClassLoader.java:58)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:197)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
    at daweb.main(daweb.java:212)
Caused by: java.lang.ClassNotFoundException: scala.ScalaObject
    at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
    ... 13 more

是否可以在没有 Scala 的情况下使用 Goose?

4

4 回答 4

3

您应该将 Scala 库添加到您的构建路径

于 2013-10-05T14:29:01.770 回答
1

问题页面中提供了一个链接,您可以在其中找到为 java 使用而编译的 .jar。 https://github.com/GravityLabs/goose/issues

import com.gravity.goose.*;


String url = "http://www.straitstimes.com/little-india-riot";
Goose goose = new Goose(new Configuration());
Article article = goose.extractContent(url);
System.out.println(article.cleanedArticleText());

这段代码作为一个开始。

于 2013-12-14T06:20:52.157 回答
1

如果您使用 Maven 管理依赖项,则只需将Goose添加到 pom.xml 的依赖项部分,它的所有传递依赖项都将在类路径中结束。

<dependency>
    <groupId>com.gravity</groupId>
    <artifactId>goose</artifactId>
    <version>2.1.22</version>
</dependency>
于 2014-07-22T05:26:56.637 回答
1

您应该将scala-libraryjar 添加到类路径中。如果您使用的是 Maven,请将此依赖项添加到您的项目中:

<dependency>
    <groupId>org.scala-lang</groupId>
    <artifactId>scala-library</artifactId>
    <version>2.10.4</version>
</dependency>
于 2015-03-02T08:58:30.127 回答