Python自动化之实现桌面壁纸下载器

随着计算机性能的提升,人们对计算机个性化的要求也越来越高了,自己使用的计算机当然要设置成自己喜欢的风格!

网站上的壁纸分类主要有美图、动漫、今日热图、壁纸等等类型的高清图片供我们下载。

若是喜欢其中的一些壁纸我们可以手动进行下载,但是对于热衷于python的我们当然要实现懒人操作-自动化批量下载。

于是就有了接下来的这个批量桌面壁纸下载器,首先将使用到的技术栈全部列举出来供大佬们参考。

  • 操作系统:windows7
  • GUI工具:PyQt5
  • 页面爬虫:requests
  • 系统文件操作库:os

其中第三方的非标准库PyQt5、requests需要我们使用pip的方式安装一下。

pip install requests -i https://pypi.tuna.tsinghua.edu.cn/simple/

pip install PyQt5 -i https://pypi.tuna.tsinghua.edu.cn/simple/

将代码块中需要的相关python模块全部导入进来。

# It's importing the traceback module.
import traceback

# Importing all the classes from the QtWidgets module.
from PyQt5.QtWidgets import *

# Importing all the classes from the QtCore module.
from PyQt5.QtCore import *

# Importing all the classes from the QtGui module.
from PyQt5.QtGui import *

# It's importing the requests module.
import requests

# It's importing the os module.
import os

# It's importing the sys module.
import sys

完成了上述的准备工作之后,我们创建一个python类WallPaperUI作为GUI布局相关的操作,将UI布局或使用到的组件全部放到这个类中来开发。

class WallPaperUI(QWidget):
    def __init__(self):
        """
        A constructor. It is called when an object is created from a class and it allows the class to initialize the
        attributes of a class.
        """
        super(WallPaperUI, self).__init__()
        self.init_ui()

    def init_ui(self):
        """
        This function initializes the UI.
        """
        self.setWindowTitle('批量桌面壁纸下载器  公众号:Python 集中营')
        self.setWindowIcon(QIcon('download.ico'))
        self.resize(500, 200)

        self.save_dir_path = QLineEdit()
        self.save_dir_path.setPlaceholderText('桌面壁纸保存路径')

        self.save_dir_btn = QPushButton()
        self.save_dir_btn.setText('保存路径')
        self.save_dir_btn.clicked.connect(self.save_dir_btn_click)

        self.set_dwonload_num_label = QLabel()
        self.set_dwonload_num_label.setText('设置下载数量:')

        self.set_dwonload_num_in = QLineEdit()
        self.set_dwonload_num_in.setPlaceholderText('例如:10')

        self.start_btn = QPushButton()
        self.start_btn.setText('立即下载')
        self.start_btn.clicked.connect(self.start_btn_click)

        self.brower = QTextBrowser()
        self.brower.setReadOnly(True)
        self.brower.setFont(QFont('宋体', 8))
        self.brower.setPlaceholderText('处理进程展示区域...')
        self.brower.ensureCursorVisible()

        hbox = QHBoxLayout()

        left_box = QVBoxLayout()
        left_box.addWidget(self.brower)

        right_box = QVBoxLayout()

        right_form_box = QFormLayout()
        right_form_box.addRow(self.save_dir_path, self.save_dir_btn)
        right_form_box.addRow(self.set_dwonload_num_label, self.set_dwonload_num_in)

        right_h_box = QHBoxLayout()
        right_h_box.addWidget(self.start_btn)

        right_box.addLayout(right_form_box)
        right_box.addLayout(right_h_box)

        hbox.addLayout(left_box)
        hbox.addLayout(right_box)

        self.download_thread = DownloadWork(self)
        self.download_thread.finished.connect(self.finished)
        self.download_thread.message.connect(self.show_message)

        self.setLayout(hbox)

    def show_message(self, text):
        cursor = self.brower.textCursor()
        cursor.movePosition(QTextCursor.End)
        self.brower.append(text)
        self.brower.setTextCursor(cursor)
        self.brower.ensureCursorVisible()

    def save_dir_btn_click(self):
        directory = QFileDialog.getExistingDirectory(self, '选择文件夹', os.getcwd())
        self.save_dir_path.setText(directory)

    def start_btn_click(self):
        self.start_btn.setEnabled(False)
        self.download_thread.start()

    def finished(self, finished):
        if finished is True:
            self.start_btn.setEnabled(True)

完成上面的界面组件布局以后GUI界面就出来了,可以看看界面效果如下。

接下来可以开发下载壁纸的业务过程了,为了避免影响页面主线程的执行过程,我们特意使用QThread的子线程来开发业务过程。

创建一个python类DownloadWork继承自QThread子线程。

class DownloadWork(QThread):
    finished = pyqtSignal(bool)
    message = pyqtSignal(str)

    def __init__(self, parent=None):
        super(DownloadWork, self).__init__(parent)
        self.working = True
        self.parent = parent

    def __del__(self):
        self.working = False

    def run(self) -> None:
        try:
            save_dir_path = self.parent.save_dir_path.text().strip()
            set_dwonload_num_in = self.parent.set_dwonload_num_in.text().strip()

            self.message.emit('保存路径:{}'.format(save_dir_path))
            self.message.emit('下载数量:{}'.format(set_dwonload_num_in))

            if save_dir_path == '':
                self.message.emit('出现错误:保存路径不能为空!')
                return

            if set_dwonload_num_in == '':
                self.message.emit('出现错误:下载数量不能为空!')
                return

            for n in range(int(set_dwonload_num_in)):
                pic_url = f"http://bingw.jasonzeng.dev?resolution=UHD&index={n}"
                self.message.emit('正在下载第{0}张壁纸!'.format(str(n)))
                with requests.get(pic_url) as r:
                    with open(os.path.join(save_dir_path, str(n) + '.jpg'), "wb") as w:
                        w.write(r.content)
            self.message.emit('全部壁纸下载完成!')
            self.finished.emit(True)
        except:
            traceback.print_exc()
            self.message.emit('执行错误,请检查参数项是否设置正确!')
            self.finished.emit(True)

至此,在子线程类DownloadWork中的壁纸下载业务就开发完了。

接下来使用python模块的mian函数调起整个应用就大功告成了。

# A special variable in Python that evaluates to True if the module is being run as the main program.
if __name__ == '__main__':
    app = QApplication(sys.argv)
    main = WallPaperUI()
    main.show()
    sys.exit(app.exec_())

最后启动应用,设置好文件保存路径,设置下载10张桌面壁纸看看效果如何?

到此这篇关于Python自动化之实现桌面壁纸下载器的文章就介绍到这了,更多相关Python桌面壁纸下载内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 编写Python脚本批量下载DesktopNexus壁纸的教程

    DesktopNexus 是我最喜爱的一个壁纸下载网站,上面有许多高质量的壁纸,几乎每天必上, 每月也必会坚持分享我这个月来收集的壁纸 但是 DesktopNexus 壁纸的下载很麻烦,而且因为壁纸会通过浏览器检测你当前分辨率来展示 合适你当前分辨率的壁纸,再加上是国外的网站,速度上很不乐观. 于是我写了个脚本,检测输入的页面中壁纸页面的链接,然后批量下载到指定文件夹中. 脚本使用 python 写的,所以需要机器上安装有 python . 用法: $ python desktop_nexus.

  • Python 批量下载阴阳师网站壁纸

    代码复制可直接使用,记得pip install下载requests和bs4 最终版本 # 引入系统类库用于打开关闭文件 import sys # 使用文档解析类库 from bs4 import BeautifulSoup # 使用网络请求类库 import requests #图片保存目录 path = 'D:/阴阳师' #阴阳师壁纸网站 html_doc = "https://yys.163.com/media/picture.html" # 请求 requests_html_do

  • python批量下载壁纸的实现代码

    复制代码 代码如下: #! /usr/bin/env python ##python2.7-批量下载壁纸 ##壁纸来自桌酷网站,所有权归属其网站 ##本代码仅做为交流学习使用,请勿用于商业用途,否则后果自负 ##Code by Dreamlikes import re,urllib,urllib2 #保存图片的路径 savepath = 'd:\\picture\\' #壁纸集合的URL,如下 url = 'http://www.zhuoku.com/zhuomianbizhi/game-gam

  • Python 下载Bing壁纸的示例

    这个示例使用的Python版本为3.7版本, 一.bing壁纸接口 访问bing的官网,通过浏览器开发者工具,查看网络可以找到一个请求壁纸的接口,至于怎么判断的,我是发现当我把鼠标放在切换壁纸的左右箭头时,发现发送了一个请求,查看请求里面是有当前的壁纸信息的,链接.描述等等-- 于是乎得到了这个接口,这个接口似乎就是获取壁纸信息的接口了 https://cn.bing.com/HPImageArchive.aspx?format=js&idx=0&n=1&nc=1600743189

  • Python实现壁纸下载与轮换

    准备 下载安装Python3 官网下载即可,选择合适的版本:https://www.python.org/downloads/ 安装一直下一步即可,记得勾选添加到环境变量. 安装pypiwin32 执行设置壁纸操作需要调用Windows系统的API,需要安装pypiwin32,控制台执行如下命令: pip install pypiwin32 工作原理 两个线程,一个用来下载壁纸,一个用来轮换壁纸.每个线程内部均做定时处理,通过在配置文件中配置的等待时间来实现定时执行的功能. 壁纸下载线程 简易的

  • python实现壁纸批量下载代码实例

    项目地址:https://github.com/jrainlau/wallpaper-downloader 前言 好久没有写文章了,因为最近都在适应新的岗位,以及利用闲暇时间学习python.这篇文章是最近的一个python学习阶段性总结,开发了一个爬虫批量下载某壁纸网站的高清壁纸. 注意:本文所属项目仅用于python学习,严禁作为其他用途使用! 初始化项目 项目使用了virtualenv来创建一个虚拟环境,避免污染全局.使用pip3直接下载即可: pip3 install virtualen

  • python 使用tkinter+you-get实现视频下载器

    运行效果: 完整代码 from tkinter import * import tkinter.messagebox import base64 from tkinter import filedialog from tkinter.scrolledtext import ScrolledText import subprocess as sub import threading import os top = Tk() top.title("欢迎关注gudu12306知乎") pat

  • Python自动化之定位方法大杀器xpath

    一.xpath:基本属性定位 上一篇文章讲了通过元素的id.name.class这些属性定位的用户,使用xpath方法结合元素属性也可以很准确的定位元素,如下图 于是可以用以下xpath方法定位 二.xpath:其他属性定位 在实际工作过程中,往往会遇到一个元素id.name.class属性都没有,这时候也可以通过其它属性定位到 三.xpath:标签定位 在实际工作中,还会遇到一种情况就是相同属性具有同一个名字,这时就需要通过标签筛选,定位更准一点 如果不想制定标签名称,可以用*号表示任意标签

  • 利用Python制作一个MOOC公开课下载器

    目录 导语 开发工具 环境搭建 先睹为快 原理简介 导语 记得很久以前写过一些中国大学MOOC上的视频下载器,不过好像都已经年久失修了.正好最近有需要,所以重新写了一个,顺便上来分享一波,寒假大家也可以用它来下载点课程内卷一下: 废话不多说,让我们愉快地开始吧~ 开发工具 Python版本:3.7.8 相关模块: DecryptLogin模块: tqdm模块: click模块: argparse模块: 以及一些python自带的模块. 环境搭建 安装Python并添加到环境变量,pip安装需要的

  • Python实现设置windows桌面壁纸代码分享

    每天换一个壁纸,每天好心情. # -*- coding: UTF-8 -*- from __future__ import unicode_literals import Image import datetime import win32gui,win32con,win32api import re from HttpWrapper import SendRequest StoreFolder = "c:\\dayImage" def setWallpaperFromBMP(imag

  • python实现多线程网页下载器

    本文为大家分享了python实现的一个多线程网页下载器,供大家参考,具体内容如下 这是一个有着真实需求的实现,我的用途是拿它来通过 HTTP 方式向服务器提交游戏数据.把它放上来也是想大家帮忙挑刺,找找 bug,让它工作得更好. keywords:python,http,multi-threads,thread,threading,httplib,urllib,urllib2,Queue,http pool,httppool 废话少说,上源码: # -*- coding:utf-8 -*- im

  • 利用Python+Excel制作一个视频下载器

    说起Excel,那绝对是数据处理领域王者般的存在. 而作为网红语言Python,在数据领域也是被广泛使用. 其中Python的第三方库-xlwings,一个Python和Excel的交互工具,可以轻松地通过VBA来调用Python脚本,实现复杂的数据分析. 今天,小F就给大家介绍一个Python+Excel的项目[视频下载器]. 主要使用到下面这些Python库. import os import sys import ssl import ffmpeg import xlwings as xw

  • python实现桌面壁纸切换功能

    本文实例为大家分享了python实现桌面壁纸切换功能的具体实现方法,供大家参考,具体内容如下 大体分为两个部分 一.利用爬虫爬取壁纸 第一部分爬取图片url地址并且下载至本地 爬虫针对 http://image.so.com/ [360壁纸写的],如果要更换url地址自己改改 import requests import json import random import os #存放Ajax图片地址数据 img_url_dict={} #创建图片tmp文件夹 if not os.path.ex

  • Python实现多线程HTTP下载器示例

    本文将介绍使用Python编写多线程HTTP下载器,并生成.exe可执行文件. 环境:windows/Linux + Python2.7.x 单线程 在介绍多线程之前首先介绍单线程.编写单线程的思路为: 1.解析url: 2.连接web服务器: 3.构造http请求包: 4.下载文件. 接下来通过代码进行说明. 解析url 通过用户输入url进行解析.如果解析的路径为空,则赋值为'/':如果端口号为空,则赋值为"80":下载文件的文件名可根据用户的意愿进行更改(输入'y'表示更改,输入

  • Python编写一个优美的下载器

    本文实例为大家分享了Python编写下载器的具体代码,供大家参考,具体内容如下 #!/bin/python3 # author: lidawei # create: 2016-07-11 # version: 1.0 # 功能说明: # 从指定的URL将文件取回本地 ##################################################### import http.client import os import threading import time impo

  • 基于python实现的百度音乐下载器python pyqt改进版(附代码)

    前言 之前写过一个用python实现的百度新歌榜.热歌榜下载器的文章,实现了百度新歌.热门歌曲的爬取与下载.但那个采用的是单线程,网络状况一般的情况下,扫描前100首歌的时间大概得到40来秒.而且用Pyqt做的界面,在下载的过程中进行窗口操作,会出现UI阻塞的现象. 前两天有时间调整了一下,做了几方面的改进: 1.修改了UI界面阻塞的问题,下载的过程中可以进行其它的UI操作; 2.爬虫程序采用一个主线程,8个子线程的方式快速爬取,网络状况一致的情况下,将扫描100首歌曲的时间提高到了8.9秒左右

随机推荐

其他