我用了30行代码,爬了知乎好多妹子

写一个爬虫有多简单?答案是:不到30行代码

我用了不到30行代码,爬了知乎好多妹子图!!!

跟着我一步一步来,你也可以简简单单创建一个爬虫。

目标

爬虫的第一步就是决定要爬些什么。作为一个屌的不能再屌的屌丝,当然要爬妹子!!!

每当这个时候,就要拿出我的储备了。 欲罢不能的大美妞 ,要说妹子图的质量,还是得知乎啊。

分析

目标有了,我们就要先分析一下。页面结构。在页面中找任一个爬取目标,点击鼠标右键,选择【检查】选项。便会打开浏览器的控制台,并定位到我们的目标图片的节点上。如下图:

图中的img标签就是我们的爬取目标,我们可以明确的看到 data-original 元素的内容与 src 元素的内容都是图片的地址。经过验证, src 元素的内容可能会是缩略图地址,所以我们放弃 src 选择 data-original。

以上就是我们要分析的部分,接下来就是代码。

编码

新建项目

这里我们使用 maven 作为项目的依赖管理工具。

新建一个 maven 项目,并在 pom.xml 中引入依赖。

<dependencies>
        <dependency>
            <groupId>com.github.zhangyingwei</groupId>
            <artifactId>cockroach</artifactId>
            <version>1.0-Alpha</version>
        </dependency>
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>
        <dependency>
            <groupId>com.squareup.okhttp3</groupId>
            <artifactId>okhttp</artifactId>
            <version>3.8.1</version>
        </dependency>
        <!--json-lib-->
        <dependency>
            <groupId>net.sf.json-lib</groupId>
            <artifactId>json-lib</artifactId>
            <version>2.4</version>
            <classifier>jdk15</classifier>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.jsoup/jsoup -->
        <dependency>
            <groupId>org.jsoup</groupId>
            <artifactId>jsoup</artifactId>
            <version>1.8.3</version>
        </dependency>
    </dependencies>

这里我们使用了爬虫框架 cockroach 。并引入了 log4j 作为日志框架,okhttp3 作为 http 客户端,json-lib 作为 json 解析工具,以及 jsoup 作为 html 解析工具。

建立包结构如下

  • store 主要存放页面解析以及结果存储相关类
  • utils 主要存放项目中用到的相关工具类
  • App.java 项目入口

编码

程序主入口 App.java

public class App {
    public static void main(String[] args) throws InstantiationException, IllegalAccessException, InterruptedException {
        CockroachConfig config = new CockroachConfig().setAppName("知乎上的妹子们").setThread(10).setStore(ZhihuGirlsStore.class);
        TaskQueue queue = TaskQueue.of();
        getPageFrom(queue);
        CockroachContext context = new CockroachContext(config);
        context.start(queue);
    }

    private static void getPageFrom(TaskQueue queue) throws InterruptedException {
        String basePath = "https://www.zhihu.com/collection/72114548?page=";
        for (int i = 1; i <= 68; i++) {
            queue.push(new Task(basePath + i));
        }
    }
}

在上边的代码中,我们一共分为5步。

  1. 我们创建了一个名称为 知乎上的妹子们 的爬虫,使用了 10 个线程来爬取内容,并指定了页面解析以及结果存储的处理类为 ZhihuGirlsStore.class
  2. 创建了一个默认长度的任务队列
  3. 初始化任务到任务队列中
  4. 创建了一个 Cockroach 爬虫上下文对象
  5. 启动爬虫

页面解析以及存储 ZhihuGirlsStore.java

public class ZhihuGirlsStore implements IStore {
    public void store(TaskResponse taskResponse) throws Exception {
        if (taskResponse.getTask().getGroup().equals("img")) {
            byte[] bytes = taskResponse.getResponse().body().bytes();
            ImageUtils.save(bytes);
        } else {
            Elements imgs = taskResponse.select(".zm-item-answer").select("img");
            imgs.stream().map(element -> element.attr("data-original")).forEach(url -> {
                try {
                    taskResponse.getQueue().push(new Task(url, "img"));
                } catch (Exception e) {
                    e.printStackTrace();
                }
            });
        }
    }
}

Cockroach 的 task 中为我们提供了 group 字段来标识每一个 任务,如果不设置,任务默认的 group 为 default 。
在本爬虫程序中,我们的 task 一共可分为两种,一种是解析页面得到页面中的图片地址,另外一种就是爬取图片内容。
这里我们通过 group 字段来区分两种任务,具体操作就是在解析到图片地址并添加到队列中的时候,给 task 设置 group 为 img,这样我们在收到一个结果的时候,就可以通过 task 中的 group 字段来区分我们要做何种操作(解析页面 / 保存图片)。

图片存储 ImageUtils.java

public class ImageUtils {
    public static void save(byte[] bytes) throws IOException {
        String fileName = UUID.randomUUID().toString();
        String dirpath = "meizhi2";
        File dir = new File(dirpath);
        if(!dir.exists()){
            dir.mkdirs();
        }
        FileOutputStream outputStream = new FileOutputStream(dirpath + "/" + fileName + ".jpg");
        outputStream.write(bytes);
        outputStream.close();
        System.out.println("save image:" + fileName);
    }
}

以上代码就是把接收到的二进制图片内容保存为图片。图片的名称使用一个随机的 UUID 值。

没错老铁们,以上就是我们的全部的代码。包括方法声明在内的有效代码不到30行!!!

文章来源

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,736评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,167评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,442评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,902评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,302评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,573评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,847评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,562评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,260评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,531评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,021评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,367评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,016评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,068评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,827评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,610评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,514评论 2 269

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 170,567评论 25 707
  • 没想到一个学校的体育测试竟然水成这样。如果你不能几个,那可以拿个及格分;及格以后,就看你跳多远了。让我惊讶的是,在...
    潇潇公主驾到阅读 154评论 0 0
  • 今天中午原本打算搜索一些英语学习视频,可是一不小心搜索出了销售彦论,结果发现根本停不下来! 从中午12:59分,一...
    余保林阅读 161评论 0 0
  • 如果,我说爱。 文/阿语花 十一月十二日晚,我梦见一个很温柔很温柔的男生。 身材比例完美,做事多为人着想,会做饭,...
    阿语花阅读 366评论 0 0
  • 夕阳西下 我牵着老马 它说脚有些疲乏 漫漫的水面难免有些眼花 深深浅浅地试探 晃晃悠悠地出发 暖黄的太阳就是方向 ...
    七彩城主阅读 337评论 0 0