IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> Python学习_不登录微博情况下根据关键字获取搜索的图片 -> 正文阅读

[网络协议]Python学习_不登录微博情况下根据关键字获取搜索的图片

  • 假设在微博主页地址输入关键字:emo表情包
  • 中文需要使用urllib_parse.quote处理
  • 表情包自定义存本地文件夹
  1. 本地运行日志如下:
    在这里插入图片描述

  2. 本地生成的文件格式为:
    在这里插入图片描述
    在这里插入图片描述

  3. 代码如下:

from selenium import webdriver
from urllib import parse
import requests
from requests.packages.urllib3.exceptions import InsecureRequestWarning
import time
import re
import os

# requests默认是keep-alive的,可能没有释放,加参数 headers={'Connection':'close'}
header = {
    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/96.0.4664.45 Safari/537.36',
    'Connection': 'close'
}
# 会忽略以下错误:InsecureRequestWarning: Unverified HTTPS request is being made to host 'wx3.sinaimg.cn'. Adding certificate
# verification is strongly advised. See: https://urllib3.readthedocs.io/en/1.26.x/advanced-usage.html#ssl-warnings
requests.packages.urllib3.disable_warnings(InsecureRequestWarning)

# 增加连接重试次数
requests.adapters.DEFAULT_RETRIES = 5

# 关闭多余的连接:requests使用了urllib3库,默认的http connection是keep-alive的,requests设置False关闭
s = requests.session()
s.keep_alive = False


# 不用ssl证书验证:verify=False
# requests.get(url, verify=False)

def makedir(filePath):
    E = os.path.exists(filePath)
    if not E:
        os.makedirs(filePath)
        os.chdir(filePath)
        print('文件夹<' + filePath + '>创建成功!')
    else:
        print('文件夹已存在!')


start_time = time.time()
# 1. 搜索图片的关键字
searchKey = 'emo表情包'
# 2. 创建当前关键字对应的文件夹
filePath = 'F:\python\pic' + '\\' + searchKey
makedir(filePath)
# 3. 处理关键字(中文会报错):https://s.weibo.com/weibo?q=%E8%A1%A8%E6%83%85%E5%8C%85
url = 'http://s.weibo.com/weibo?q=' + parse.quote(searchKey)
print('关键字[' + searchKey + ']的待处理地址:' + str(url))


def getDownloadUrl():
    # 4. 模仿浏览器行为
    options = webdriver.ChromeOptions()
    options.add_experimental_option('excludeSwitches', ['enable-logging'])
    web = webdriver.Chrome(options=options)
    web.get(url)
    time.sleep(6)  # 给点时间获取网页内容
    wb_resp = web.page_source  # 返回网页源代码
    web.close()  # 打开的网页要及时关闭
    return re.findall('img src="(?P<src>.*?)"', wb_resp)


if __name__ == '__main__':
    download_link = getDownloadUrl()
    print('待下载图片为:' + str(len(download_link)) + '个')

    if len(download_link) > 0:
        for link in download_link:
            try:
                if str(link).find('http') < 0:
                    link = "http:" + link
                image_resp = requests.get(link, headers=header, verify=False)
                # 为了避免命名重复导致报错,使用其中的一直在变化的一串数字来作为文件名
                image_name = link.split("?")[0].split("/")[-1]
                # 文件名称
                # 创建Bytes形式的图片文件,把数据写入图片文件中,保存在文件中,打开方式为二进制写模式
                with open(filePath + '\\' + image_name, mode="wb") as f:
                    f.write(image_resp.content)
                # time.sleep(3)
                image_resp.close()
            except Exception as e:
                image_resp.close()
                print(e)

# 结束时间
print('全部图片已完成下载,总耗时为:' + str(time.time() - start_time))

以上,只获取当前请求页的图片,如果想获取更多,F12了解到还有一个请求url:https://s.weibo.com/ajax/topsuggest.php
可以拿到与搜索词相关的博主id信息,然后直接去抓博主页的表情包也可以
在这里插入图片描述
在这里插入图片描述

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2021-12-02 17:07:55  更:2021-12-02 17:09:00 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 5:27:09-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码