Python爬虫入门教程: 半次元COS图爬取-深圳网站优化推广公司

Python爬虫入门教程: 半次元COS图爬取

2019-05-08 07:29:15来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

半次元COS图爬取-写在前面

今天在浏览网站的时候,忽然一个莫名的链接指引着我跳转到了半次元网站 https://bcy.net/ 打开之后,发现也没有什么有意思的内容,职业的敏感让我瞬间联想到了 cosplay ,这种网站必然会有这个的存在啊,于是乎,我准备好我的大爬虫了。


 

在这里插入图片描述

把上面的链接打开之后,被我发现了吧,就知道我的第八感不错滴。接下来就是找入口,一定要找到图片链接的入口才可以做下面的操作
在这里插入图片描述

这个页面不断往下拖拽,页面会一直加载,当时当你拖拽一会,就停下来了,就是这个时机
在这里插入图片描述

发现入口,在我实际的操作中,其实还发现了很多其他的入口,这个就不一一的解释了,赶紧上车,进入 view more 之后,发现了页面依旧是一个下拉刷新的布局方式,专业术语 瀑布流 。

半次元COS图爬取-python爬虫第一步

打开开发者工具,切换到network之后,发现 很多xhr请求,发现这个,就代表这个网站很容易爬取了

在这里插入图片描述
提取待爬取的链接,分析规律

https://bcy.net/circle/timeline/loadtag?since=0&grid_type=timeline&tag_id=1482&sort=hot
https://bcy.net/circle/timeline/loadtag?since=26499.779&grid_type=timeline&tag_id=1482&sort=hot
https://bcy.net/circle/timeline/loadtag?since=26497.945&grid_type=timeline&tag_id=1482&sort=hot

发现只有一个参数在变,而且这变化好像没有任何规律可以寻找,没事,看数据,你就可以发现其中的奥妙了

在这里插入图片描述
这个网站的原理很简单,就是通过不断获取每次数据的最后一条的since然后获取接下来的数据,那么我们按照它的规律实现代码就可以了,不要多线程了,这种规律是没有办法进行实操的。
这次的数据我把它存储到mongodb里面,因为没有办法一次全部获取到,所以可能需要下次在继续使用

if __name__ == '__main__':
    ###  mongodb 的一些基本操作   
    DATABASE_IP = '127.0.0.1'
    DATABASE_PORT = 27017
    DATABASE_NAME = 'sun'
    start_url = "https://bcy.net/circle/timeline/loadtag?since={}&grid_type=timeline&tag_id=399&sort=recent"
    client = MongoClient(DATABASE_IP, DATABASE_PORT)

    db = client.sun
    db.authenticate("dba", "dba")
    collection  =  db.bcy  # 准备插入数据
    #####################################3333
    get_data(start_url,collection)

获取网页数据这个地方,由我们前面的经验就变得很简单了

## 半次元COS图爬取-获取数据函数  
def get_data(start_url,collection):
    since = 0
    while 1:
        try:
            with requests.Session() as s:
                response = s.get(start_url.format(str(since)),headers=headers,timeout=3)
                res_data = response.json()
                if res_data["status"] == 1:
                    data = res_data["data"]  # 获取Data数组
                    time.sleep(0.5)
                ## 数据处理
                since = data[-1]["since"]  # 获取20条数据的最后一条json数据中的since
                ret = json_handle(data)   # 代码实现在下面
                try:
                    print(ret)
                    collection.insert_many(ret)   # 批量出入数据库
                    print("上述数据插入成功!!!!!!!!")
                except Exception as e:
                    print("插入失败")
                    print(ret)

                ##
        except Exception as e:
            print("!",end="异常,请注意")
            print(e,end=" ")
    else:
        print("循环完毕")

网页解析代码

# 对JSON数据进行处理
def json_handle(data):
    # 提取关键数据
    list_infos = []
    for item in data:
        item = item["item_detail"]
        try:
            avatar = item["avatar"] # 用户头像
            item_id = item["item_id"] # 图片详情页面
            like_count = item["like_count"] # 喜欢数目
            pic_num = item["pic_num"] if "pic_num" in item else 0 # 图片总数
            reply_count =item["reply_count"]
            share_count =item["share_count"]
            uid = item["uid"]
            plain = item["plain"]
            uname = item["uname"]
            list_infos.append({"avatar":avatar,
                               "item_id":item_id,
                               "like_count":like_count,
                               "pic_num":pic_num,
                               "reply_count":reply_count,
                               "share_count":share_count,
                               "uid":uid,
                               "plain":plain,
                               "uname":uname})
        except Exception as e:
            print(e)
            continue
        return list_infos

到现在就实现了,代码跑起来
在这里插入图片描述

小编整理一套Python资料和PDF,有需要Python学习资料可以加学习群:1004391443,反正闲着也是闲着呢,不如学点东西啦~~



原文链接:https://www.cnblogs.com/qingdeng123/p/10809662.html
如有疑问请与原作者联系

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:python中基于tcp协议的通信(数据传输)

下一篇:20190505-旋转数字

相关内容推荐

长春网站制作哪好吉网传媒优直播网站的制作教程忻州网站制作好不好用html制作淘宝网站沧县网站制作电话忠县网站建设制作35互联制作的网站制作人力资源网站首页网站制作答辩ppt怎么做制作esl网站html制作博客网站襄阳网站制作策划临沂制作网站价格怎么制作游戏网站logofiash制作特效网站怎么查看网站是用什么制作的二手交易网站怎么制作有什么制作精美PPT的网站企业网站制作代理瑞安 网站 制作18课网站制作制作公司网站设河北手机网站制作学生个人博客网站制作富平网站制作建平中学网站制作游戏网站制作起泡阳泉购物网站开发制作广告制作网站大全利川搬家网站制作宁波宁海营销型网站制作山东服务网站制作公司舞曲网站制作雪糕金华网站制作公司排名桐乡网站设计制作什么价格百度竞价单页网站制作湛江市研发网站制作平台企石五金网站制作好不好中山网站程序开发制作一个网站如何制作多个网址制作医院网站的素材五五影视网站制作餐饮网站建设制作手工网站制作联系地址无锡网站制作应觅新互动网络温州制作网站公司有哪些一站式3dvr制作网站永康制作好网站如何设置站点心动的感觉表情在线制作网站聊城专业网站建设制作价格淄博网站制作网页网络怎样制作文档网站教程新乡网站制作优化南漳专业的网站制作总部收音机制作网站网站前台制作的体验和经验总结制作工作照网站逍遥网站制作奶茶电子网站制作哪家公司好非主流图片素材网站制作港剧网站制作书签中东战争纪录片网站制作澳门手机网站制作统计图表制作网站制作网站要学些什么吴忠个人网站开发制作乐从企业网站制作江西网站制作多少钱宝安网站建设制作费用山东制作网站费用自贡自适应网站制作淘客网站程序dw制作模板东莞网站制作很棒 乐云践新网站的制作模板免费下载垂钓网站制作5200小说网站制作5566网站制作贴纸温岭福田分类网站制作都有哪些免费seo网站制作有哪些表格制作excel网站公司小语种网站制作网站制作要求有超链接初中信息技术网站制作望谟网站制作加盟装潢网站制作模板威海 网站制作武冈网站建设制作steam背景制作网站新闻发布系统 网站制作中国专业英文旅游网站制作濉溪县网站制作公司哪些网站有专业的美食制作通讯网站制作美食微信小程序怎么制作动态网站海盐佛山网站制作哪里实惠綦江品牌网站制作公司哪家好微信扫码制作表格是哪个网站制作网站添加地图可以制作动态图拼接的网站从化区网站建设制作滕州租房网站制作录播网站制作雪糕企业网站设计制作要点安康网站制作企业经济型网站制作哪家好嘉兴网站建设开发与制作免费制作网站平台可以吗华山网站制作美食vr网站制作多少钱网站前台制作的体验和经验总结木质素材网站制作曹县定制企业网站制作价格模板网站制作哪家好安卓网站制作表情包跆拳道网站制作小玩具北京网站制作套餐大型网站制作o宜春制作网站设计费用多少汕头市专注网站制作东城门户网站制作创新论文网站制作专属签名制作网站网站改版制作咨询归元寺网站视频制作手工制作的胸针上什么网站好卖中关村一小网站制作北京网站制作哪些好装修公司网站制作联系方式鞍山铁西区网站制作万部电影网站制作单页网站制作成本学网站制作难么亦庄网站制作平台普通制作网站多少钱网站制作棋牌演示制作网站空间河南网站制作干花相框武隆网站制作公司择优推荐一大把网站制作场景图制作的网站快速制作网站flash乐从企业网站制作义乌石景山网站制作费用多少制作班徽网站武昌网站制作报价帝国网站管理系统 标签制作网站制作p是什么意思淮南网站制作壁纸海盐网站制作设计哪里有单页网站免费制作软件临汾网站制作案例奉贤网站制作哪家好无锡网站设计与网页制作湘潭网站制作广告设计网站视频制作收费廊坊家电维修网站制作安装个人网站制作美食文案神奇的网站制作用友软件有网站制作业务吗手机和pc网站制作重庆忠县网站制作案例新泰网站制作设计珲春自适应网站制作益阳微网站制作商城网站制作冰淇淋侯马自适应网站制作自己网站制作视频教程网站制作水泥瓦价格小木虫网站制作表情包教育加盟网站的制作费用什么是网站制作域名网站地图制作生成云网站制作书签灵宝网站制作建设大庆制作网站公司汉中网站设计制作多少钱山东服务网站制作公司珠海网站制作首页无锡网站制作优选新互动网络宣威市网站制作塘下网站建设制作联想网站制作小玩具vs2017制作网站教程如何制作网站变成软件制作网站资源免费俄语网站制作上海电商网站开发制作讷河手机app网站制作ZENCART模板网站制作邀请函网站制作如何制作问卷星网站汾阳自适应网站制作制作网站软件office制作网站如何添加收藏美食网站栏目设计与制作傻瓜网站制作干花巴中企业网站制作制作网站的一般步骤5个周末电影网站制作宁陵定制制作网站价格

合作伙伴

深圳网站优化推广公司

龙岗网络公司
深圳网站优化
龙岗网站建设
坪山网站建设
百度标王推广
天下网标王
SEO优化按天计费
SEO按天计费系统