NatureSearchPageProcessor.java 3.51 KB
package com.canrd.webmagic.processor;

import us.codecraft.webmagic.Page;
import us.codecraft.webmagic.Site;
import us.codecraft.webmagic.Spider;
import us.codecraft.webmagic.processor.PageProcessor;
import us.codecraft.webmagic.selector.Html;
import us.codecraft.webmagic.selector.Selectable;
import us.codecraft.webmagic.selector.XpathSelector;

import java.util.List;

/**
 * @author: xms
 * @description: TODO
 * @date: 2024/4/1 14:19
 * @version: 1.0
 */
public class NatureSearchPageProcessor implements PageProcessor {

    // 抓取网站的相关配置,包括编码、抓取间隔、重试次数等
    private Site site = Site.me().setRetryTimes(3).setSleepTime(100);

    /**
     * 定制爬虫逻辑的核心接口,在这里编写抽取逻辑
     *
     * @param page
     */
    @Override
    public void process(Page page) {
        if ("https://www.nature.com/search?q=battery&page=1".equals(page.getUrl().get())) {
            doArticleList(page);
        } else  {
            doArticleContent(page);
        }

    }

    private void doArticleContent(Page page) {
        //解析页面
        Html html = page.getHtml();
        String title = html.xpath("//div[@class='c-article-header']/header/div/h1/text()").get();
        Selectable selectable = page.getHtml().$(".c-article-author-list c-article-author-list--short js-no-scroll").select(
                new XpathSelector("li[@class='c-article-author-list__item']"));
        List<Selectable> nodes = selectable.nodes();
        StringBuffer authorName = new StringBuffer();
        for (Selectable node : nodes) {
            authorName.append(node.xpath("//a/text()"));
        }
        System.out.println("标题:" + title);
    }

    private void doArticleList(Page page) {
        String url = page.getUrl().get();
        String[] split = url.split("=");
        Integer pageIndex = Integer.parseInt(split[split.length - 1]);
        /**
         * 通过page.getHtml()可以获取到main函数中Spider.create(new BaiduHotSearchPageProcessor()).addUrl中的地址的网页内容
         * 1、通过$或css()方法获取到该page html下某元素dom
         */
        Selectable selectable = page.getHtml().$(".app-article-list-row").select(
                new XpathSelector("li[@class='app-article-list-row__item']")
        );
        List<Selectable> nodes = selectable.nodes();

        /**
         * 获取到指定的dom后,从这些dom中提取元素内容。
         */
        for (int i = 1; i <= nodes.size() - 1; i++) {
            Selectable node = nodes.get(i).$(".u-full-height").nodes().get(2).nodes().get(0).$(".u-full-height").select(new XpathSelector("a[@class='c-card__link u-link-inherit']")).nodes().get(0);
            String link = node.$("a", "href").get();
            page.addTargetRequest(link);
            String link1 = node.links().get();
            String title = node.$("a", "text").get();
            System.out.printf("%d、%s,访问地址:%s%n", i, title, link1);
        }
//        page.addTargetRequest("https://www.nature.com/search?q=battery&page=" + pageIndex);
    }

    @Override
    public Site getSite() {
        return site;
    }

    public static void main(String[] args) {
        // 创建一个Spider,并把我们的处理器放进去
        Spider.create(new NatureSearchPageProcessor())
                // 添加这个Spider要爬取的网页地址
                .addUrl("https://www.nature.com/search?q=battery&page=1")
                // 开启5个线程执行,并开始爬取
                .thread(5).run();
    }
}