taobao.go

package main

import (
    "crypto/md5"
    "encoding/hex"
    "fmt"
    "github.com/PuerkitoBio/goquery"
    "github.com/hunterhug/go_tool/spider"
    "github.com/hunterhug/go_tool/spider/query"
    "github.com/hunterhug/go_tool/util"
    "regexp"
    "strings"
)

func main() {
    fmt.Println(`欢迎使用淘宝天猫图片下载小工具,在同级目录写入链接进taobao.txt,运行EXE即可`)
    fmt.Println("链接如:tmall.com/item.htm?id=523350171126&skuId=3120562159704,tmall")
    fmt.Println("---------------以上详情页中图片会保存在tmall目录-----------------------")
    c, e := util.ReadfromFile("./taobao.txt")
    if e != nil {
        fmt.Println("打开taobao.txt出错")
    } else {
        urls := strings.Split(string(c), "\n")
        for _, url := range urls {
            url := strings.Replace(strings.TrimSpace(url), "\r", "", -1)
            downlod(url)
        }

    }
    fmt.Println("请手动关闭选框...")
    util.Sleep(100)
}

func md55(s string) string {
    h := md5.New()
    h.Write([]byte(s))
    rs := hex.EncodeToString(h.Sum(nil))
    return rs
}

func downlod(urlmany string) {
    temp := strings.Split(urlmany, ",")
    url := temp[0]
    filename := util.TodayString(3)
    if len(temp) >= 2 {
        filename = temp[1]
    }
    dir := "./" + filename
    util.MakeDir(dir)
    s, e := spider.NewSpider(nil)
    if e != nil {

    } else {
        s.Url = url
        dudu := "detail.tmall.com"
        if strings.Contains(url, "item.taobao.com") {
            dudu = "item.taobao.com"
        }
        s.NewHeader("Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.99 Safari/537.36", dudu, nil)
        content, err := s.Get()
        if err != nil {

        } else {
            //fmt.Println(string(content))
            docm, err := query.QueryBytes(content)
            if err != nil {
                fmt.Println(err.Error())
            } else {
                //fmt.Println(string(content))
                docm.Find("img").Each(func(num int, node *goquery.Selection) {
                    img, e := node.Attr("src")
                    if e == false {
                        img, e = node.Attr("data-src")
                    }
                    if e && img != "" {
                        if strings.Contains(img, ".gif") {
                            return
                        }
                        fmt.Println("原始文件:" + img)
                        r, _ := regexp.Compile(`([\d]{1,4}x[\d]{1,4})`)
                        imgdudu := r.FindStringSubmatch(img)
                        sizes := "720*720"
                        if len(imgdudu) == 2 {
                            sizes = imgdudu[1]
                        }
                        temp := strings.Replace(img, sizes, "720x720", -1)
                        filename := md55(temp)
                        if util.FileExist(dir + "/" + filename + ".jpg") {
                            fmt.Println("文件存在:" + dir + "/" + filename)
                        } else {
                            fmt.Println("下载:" + temp)
                            s.Url = "http:" + temp
                            imgsrc, e := s.Get()
                            if e != nil {
                                fmt.Println("下载出错" + temp + ":" + e.Error())
                                return
                            }
                            e = util.SaveToFile(dir+"/"+filename+".jpg", imgsrc)
                            if e == nil {
                                fmt.Println("成功保存在" + dir + "/" + filename)
                            }
                            util.Sleep(2)
                            fmt.Println("暂停两秒")
                        }
                    }
                })

            }

        }
    }

}

在源码同级目录写入taobao.txt:

https://detail.tmall.com/item.htm?id=523350171126&skuId=3120562159704,myword

图片将会保存在myword里面

首先安装库

go get -v github.com/PuerkitoBio/goquery
go get -v github.com/hunterhug/go_tool

然后开跑!

go run taobao.go

如果嫌麻烦

请到这里下载打包exe执行文件:

http://pan.baidu.com/s/1jHKUGZG

进入go目录,下载taobao.rar

源码在:

https://github.com/hunterhug/taobao_img

截图如下:


少于150字的随笔不允许发布到首页候选区
少于150字的随笔不允许发布到首页候选区
少于150字的随笔不允许发布到首页候选区
少于150字的随笔不允许发布到首页候选区
少于150字的随笔不允许发布到首页候选区
少于150字的随笔不允许发布到首页候选区
少于150字的随笔不允许发布到首页候选区
少于150字的随笔不允许发布到首页候选区
少于150字的随笔不允许发布到首页候选区
少于150字的随笔不允许发布到首页候选区
少于150字的随笔不允许发布到首页候选区
少于150字的随笔不允许发布到首页候选区
少于150字的随笔不允许发布到首页候选区
少于150字的随笔不允许发布到首页候选区

抓取天猫和淘宝的详情页图片|Golang的更多相关文章

  1. 仿淘宝商品详情页上拉弹出新ViewController

    新项目就要开始做了,里面有购物那块,就试着先把淘宝商品详情页的效果做了一下. 1.需求 1.第一次上拉时,A视图拉到一定距离将视图B从底部弹出,A视图也向上 2.显示B视图时下拉时,有刷新效果,之后将 ...

  2. iOS app url scheme跳转到淘宝商品详情页 唤醒app

    最近涉及的一个业务,在app内的一个广告,点击打开webView,加载的是一个淘宝商品详情页,效果是打开该webView自动跳转至淘宝对应的页面,同时在自己的app仍然加载页面,点击评论等也同样能跳转 ...

  3. 第十二篇、OC_仿淘宝商品详情页的翻页

    // // GFBProductViewController.m // elmsc // // Created by MAC on 2016/11/26. // Copyright © 2016年 G ...

  4. android仿京东、淘宝商品详情页上拉查看详情

    话不多说,直接上干货,基本就是一个scrollview中嵌套两个scrollview或者webview;关键点事处理好子scrollview和父scrollview的触摸.滑动事件已达到想要的效果.大 ...

  5. vue实现淘宝商品详情页属性选择功能

    方法一是自己想出来的,方法二来自忘记哪里看到的了 不知道是不是你要的效果: 方法一:利用input[type="radio"] css代码: input { display: no ...

  6. 仿京东淘宝商品详情页属性选择js效果

    在网上找了好久发现都不符合要求就自己摸索写了一个,用到了linq.js这个linq to js 扩展,不然用纯JS遍历json查询要死人啊 demo:http://123.207.28.46:8086 ...

  7. 【Python3 爬虫】14_爬取淘宝上的手机图片

    现在我们想要使用爬虫爬取淘宝上的手机图片,那么该如何爬取呢?该做些什么准备工作呢? 首先,我们需要分析网页,先看看网页有哪些规律 打开淘宝网站http://www.taobao.com/ 我们可以看到 ...

  8. python爬虫爬取京东、淘宝、苏宁上华为P20购买评论

    爬虫爬取京东.淘宝.苏宁上华为P20购买评论 1.使用软件 Anaconda3 2.代码截图 三个网站代码大同小异,因此只展示一个 3.结果(部分) 京东 淘宝 苏宁 4.分析 这三个网站上的评论数据 ...

  9. Vue实现仿淘宝商品详情属性选择的功能

    Vue实现仿淘宝商品详情属性选择的功能 先看下效果图:(同个属性内部单选,属性与属性之间可以多选) 主要实现过程: 所使用到的数据类型是(一个大数组里面嵌套了另一个数组)具体格式如下:   attrA ...

随机推荐

  1. java ftp

    FTPUtil import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import jav ...

  2. 缓存技术比拼:Redis与Memcached的同与不同

    转至:http://developer.51cto.com/art/201603/507980.htm 在今天的文章中,我们将探讨Redis(REmote DIctionary Server).Red ...

  3. uml入门之14图与图之间的关系

    1.先奉上整理的14图. 2.其次奉上整理的图之间的6种关系

  4. javascript函数中的三个技巧【二】

    技巧二: [惰性载入函数] 因为浏览器之间的行为的差异,我们经常会在函数中包含了大量的if语句,以检查浏览器特性,解决不同浏览器的兼容问题,比如,我们最常见的为dom节点添加时间的函数 functio ...

  5. Oracle执行计划与统计信息的一些总结

    [日期:2011-08-05]来源:Linux社区  作者:wangshengfeng1986211[字体:大 中 小] 2010-07-01 15:03 1.SET AUTOTRACE ON EXP ...

  6. Runtime 方法替换 和 动态添加实例方法 结合使用

    前言: 方法替换,可以替换任意外部类的方法,而动态添加方法只能实现在被添加类创建的对象里,但是将方法替换和动态添加方法结合使用,可以实现,对任意外部类动态添加需要的方法,这个方法可以是类方法也可以是实 ...

  7. Android 之 2048 的游戏逻辑分析

    继续学习了极客学院的实战路径课程,讲到了2048游戏的编写过程,我在这里作个总结分享给大家(结果会附源代码和我改写后的代码): 这里主要包括两个方面:1.2048界面的绘制   2.2048算法逻辑的 ...

  8. 远离腰痛的好方法——如何锻炼腰背部肌肉?

    在我们的骨科门诊中最常见到的就是腰痛患者:引起腰痛的原因很多,也比较复杂,所以就有俗语"病人腰痛.医生头痛"一说.其实,相当大部分的腰痛症状都是跟腰背部后方的肌肉筋膜劳损或者无菌性 ...

  9. PHP实例学习之————MVC架构模式分析与设计

      写博客,不容易,你们的评论和转载,就是我的动力, 但请注明出处,隔壁老王的开发园:http://www.cnblogs.com/titibili 2016年1月31日 18:53 作者:Ygirl ...

  10. SQLServer中登录名的用户名配置

    其实这个问题困扰我很久了. 今夏(13.7)实习的时候第一次接触sqlserver 当时是统一安排,按部就班的做就行. 那时候链接数据库用的id是sa. 后来自己做小程序时候举得不管什么都用sa登录好 ...