我试图从“纽约时报”网址得到新闻文章,但它没有提供任何输出,但如果我尝试任何其他报纸,它就会提供输出。我想知道我的代码是否出了问题,或者boiler导管无法获取它。另外,有时输出不是英语,意思是它在unicode中显示的主要是“每日新闻”,我也想知道原因。进口java.io.InputStream;进口java.net.URL;
import org.xml.sax.InputSource;
import de.l3s.boilerpipe.document.TextDocument;
import de.l3s.boilerpipe.extractors.ArticleExtractor;
import de.l3s.boilerpipe.extractors.DefaultExtractor;
import de.l3s.boilerpipe.sax.BoilerpipeSAXInput;
class ExtractData
{
public static void main(final String[] args) throws Exception
{
URL url;
url = new URL(
"http://www.nytimes.com/2013/03/02/nyregion/us-judges-offer-addicts-a-way-to-avoid-prison.html?hp&_r=0");
// NOTE We ignore HTTP-based character encoding in this demo...
final InputStream urlStream = url.openStream();
final InputSource is = new InputSource(urlStream);
final BoilerpipeSAXInput in = new BoilerpipeSAXInput(is);
final TextDocument doc = in.getTextDocument();
urlStream.close();
// You have the choice between different Extractors
//System.out.println(DefaultExtractor.INSTANCE.getText(doc));
System.out.println(ArticleExtractor.INSTANCE.getText(doc));
}
}发布于 2015-02-22 20:46:18
Nytimes.com有一个付费墙,它为您的请求返回HTTP 303,您可以尝试使用处理重定向和cookie。尝试其他用户代理字符串也可能有效。
https://stackoverflow.com/questions/28606469
复制相似问题