Java爬取 百度图片Google图片Bing图片
先看看抓取的结果。



8个Java类:
- Startup.java - main函数
- ImageCrawler.java - Crawler基类
- BaiduImageCrawler.java - 百度图片的具体爬取实现
- GoogleImageCrawler.java - Google图片的具体爬取实现
- BingImageCrawler.java - Bing图片的具体爬取实现
- ImageWorker.java - 定时从Queue中取图片URL下载(默认开启100个)
- ImageDownloader.java - 图片下载
- MD5Checksum.java - 文件MD5计算(文件去重)
- public class BaiduImageCrawler extends ImageCrawler {
- //tn:resultjsonavatarnew
- //ie:utf-8 字符编码(ie输入 oe输出)
- //word:美女 搜索关键字
- //pn:60 开始条数
- //rn:30 显示数量
- //z:0 尺寸(0全部尺寸 9特大 3大 2中 1小)
- //width:1024 自定义尺寸-宽
- //height:768 自定义尺寸-高
- //ic:0 颜色(0全部颜色 1红色 2黄色 4绿色 8青色 16蓝色 32紫色 64粉色 128棕色 256橙色 512黑色 1024白色 2048黑白)
- //s:0 3头像图片
- //face:0 1面部特写
- //st:-1 -1全部类型 1卡通画 2简笔画
- //lm:-1 (6动态图片 7静态图片)
- //gsm:3c pn值的十六进制数
- private static final String BAIDU_IMAGE_SEARCH_URL = "http://image.baidu.com/search/avatarjson?tn=resultjsonavatarnew&ie=utf-8&word=%s&pn=%d&rn=%d&z=3&ic=0&s=0&face=0&st=-1&lm=-1&gsm=%s";
- private static final int PAGE_SIZE = 60;
- private static final String IMAGE_URL_REG = "\"objURL\":\"(https?://[^\"]+)\"";
- private static final Pattern IMAGE_PATTERN = Pattern.compile(IMAGE_URL_REG);
- @Override
- public String getSearchUrl(String keyword, int page) {
- int begin = page * PAGE_SIZE;
- return String.format(BAIDU_IMAGE_SEARCH_URL, keyword, begin, PAGE_SIZE, Integer.toHexString(begin));
- }
- @Override
- public int parseImageUrl(ConcurrentLinkedQueue<String> queue, StringBuffer data) {
- int count = 0;
- Matcher matcher = IMAGE_PATTERN.matcher(data);
- while (matcher.find()) {
- queue.offer(matcher.group(1));
- count++;
- }
- return count;
- }
- }
- public class GoogleImageCrawler extends ImageCrawler {
- //tbm=isch
- //q=美女 搜索关键字
- //ijn=0 页码(***Google只提供到0到8页数据!)
- //start=0 开始条数
- //tbs=isz:l 搜索条件
- // 尺寸
- // tbs=isz:l 大
- // tbs=isz:m 中
- // 颜色
- // tbs=ic:color 彩色
- // tbs=ic:gray 黑白
- // tbs=ic:trans 透明
- // 类型
- // tbs=itp:face 脸部特写
- // tbs=itp:photo 照片
- // tbs=itp:clipart 剪贴画
- // tbs=itp:lineart 素描画
- // tbs=itp:animated 动画
- // 条件组合
- // tbs=isz:l,ic:color,itp:face
- private static final String GOOGLE_IMAGE_SEARCH_URL = "https://www.google.com/search?tbm=isch&q=%s&ijn=%d&start=%d&tbs=isz:l";
- private static final int PAGE_SIZE = 100;
- private static final String IMAGE_URL_REG = "\"ou\":\"(https?://[^\"]+)\"";
- private static final Pattern IMAGE_PATTERN = Pattern.compile(IMAGE_URL_REG);
- @Override
- public String getSearchUrl(String keyword, int page) {
- int begin = page * PAGE_SIZE;
- return String.format(GOOGLE_IMAGE_SEARCH_URL, keyword, page, begin);
- }
- @Override
- public int parseImageUrl(ConcurrentLinkedQueue<String> queue, StringBuffer data) {
- int count = 0;
- Matcher matcher = IMAGE_PATTERN.matcher(data);
- while (matcher.find()) {
- queue.offer(matcher.group(1));
- count++;
- }
- return count;
- }
- }
- public class BingImageCrawler extends ImageCrawler {
- //async=content
- //q=美女 搜索关键字
- //first=118 开始条数
- //count=35 显示数量
- private static final String BING_IMAGE_SEARCH_URL = "http://www.bing.com/images/async?async=content&q=%s&first=%d&count=%d";
- private static final int PAGE_SIZE = 35;
- private static final String IMAGE_URL_REG = "imgurl:"(https?://[^,]+)"";
- private static final Pattern IMAGE_PATTERN = Pattern.compile(IMAGE_URL_REG);
- @Override
- public String getSearchUrl(String keyword, int page) {
- int begin = page * PAGE_SIZE;
- return String.format(BING_IMAGE_SEARCH_URL, keyword, begin, PAGE_SIZE);
- }
- @Override
- public int parseImageUrl(ConcurrentLinkedQueue<String> queue, StringBuffer data) {
- int count = 0;
- Matcher matcher = IMAGE_PATTERN.matcher(data);
- while (matcher.find()) {
- queue.offer(matcher.group(1));
- count++;
- }
- return count;
- }
- }
Java爬取 百度图片Google图片Bing图片的更多相关文章
- JAVA爬取百度贴吧图片
package com.wang.xiaowei.utils; import com.sun.image.codec.jpeg.JPEGCodec; import com.sun.image.code ...
- 使用python爬取百度贴吧内的图片
1. 首先通过urllib获取网页的源码 # 定义一个getHtml()函数 def getHtml(url): try: page = urllib.urlopen(url) # urllib.ur ...
- Python 爬虫练习: 爬取百度贴吧中的图片
背景:最近开始看一些Python爬虫相关的知识,就在网上找了一些简单已与练习的一些爬虫脚本 实现功能:1,读取用户想要爬取的贴吧 2,读取用户先要爬取某个贴吧的页数范围 3,爬取每个贴吧中用户输入的页 ...
- java爬取百度首页源代码
爬虫感觉挺有意思的,写一个最简单的抓取百度首页html代码的程序.虽然简单了一点,后期会加深的. package test; import java.io.BufferedReader; import ...
- 百度图片爬虫-python版-如何爬取百度图片?
上一篇我写了如何爬取百度网盘的爬虫,在这里还是重温一下,把链接附上: http://www.cnblogs.com/huangxie/p/5473273.html 这一篇我想写写如何爬取百度图片的爬虫 ...
- python 3 爬取百度图片
python 3 爬取百度图片 学习了:https://blog.csdn.net/X_JS612/article/details/78149627
- Python 爬虫实例(1)—— 爬取百度图片
爬取百度图片 在Python 2.7上运行 #!/usr/bin/env python # -*- coding: utf-8 -*- # @Author: loveNight import jso ...
- Python爬虫实例(一)爬取百度贴吧帖子中的图片
程序功能说明:爬取百度贴吧帖子中的图片,用户输入贴吧名称和要爬取的起始和终止页数即可进行爬取. 思路分析: 一.指定贴吧url的获取 例如我们进入秦时明月吧,提取并分析其有效url如下 http:// ...
- selenium+chrome浏览器驱动-爬取百度图片
百度图片网页中中,当页面滚动到底部,页面会加载新的内容. 我们通过selenium和谷歌浏览器驱动,执行js,是浏览器不断加载页面,通过抓取页面的图片路径来下载图片. from selenium im ...
随机推荐
- Storm实践
1.Storm命令 在Linux中观直接输入Storm,不带任何参数信息,可以查看Storm命令. 参考这里 1. activate 激活指定的拓扑Spout.语法:storm activate t ...
- Centos安装jdk8
1.下载jdk1.8的tar cd /usr/local/src #切换到该目录下 wget url #下载jdk8的tar包 2.下载完成后解压tar包 tar -zxvf jdk-8u152-li ...
- 在wamp中添加php新版本
新的公司,要求用php5.3,只记得PHP出到7了,5.3不知道是之前什么时候的了呢.不过公司要求,照办就是. 从网上看了看教程,挺简单的,就是5.3的php资源的寻找.找到了,存到了自己云盘,嘿嘿, ...
- MySQL通过localhost无法连接数据库的解决
问题:一台服务器的PHP程序通过localhost地址无法连接数据库,但是如果设置为127.0.0.1则可以正常连接,连接其他数据库服务器也正常.MySQL的权限设置正确,且通过mysql命令行客户端 ...
- freemarker写select组件(二)
freemarker写select组件 1.宏定义 <#macro select id datas value=""> <select id="${id ...
- vue轮播组件及去掉路由#
最近公司要我去实现vue知识的系统讲解,总结一番,大致需要7节课,今天大致说一下我们使用vue需要学会的基本技能.vue是一个渐进性视图渲染框架,使用vue核心是数据出发,数据一般是我们前台从后台获取 ...
- MFC 中线程传递CString 是不安全的 转
MFC 中线程传递CString 是不安全的 在MFC中,向线程传递CString变量参数时,很容易犯一个错误,就是使用一个超出生存期的变量,在主函数中定义的CString变量是局部变量 ...
- AJAX的简洁写法
// ajax操作 $('#btn').on('click',function(){ var url = "{:url('confirm')}"; var actual_money ...
- Html行内元素和块级元素
1.关于行内元素和块状元素的说明 根据CSS规范的规定,每一个网页元素都有一个display属性,用于确定该元素的类型,每一个元素都有默认的display属性值,比如div元素,它的默认display ...
- 【BZOJ2882】工艺(后缀数组)
[BZOJ2882]工艺(后缀数组) 题面 BZOJ权限题,我爱良心洛谷 题解 最容易的想法: 把字符串在后面接一份 然后求后缀数组就行了... #include<iostream> #i ...