作者: AI最严厉的父亲

  • 如何使用Python爬取豆瓣电影Top250的电影海报

    作为一位电影爱好者,你可能经常关注豆瓣电影上的Top250电影榜单,想要了解哪些电影备受推崇。而且,你可能也希望将一些你喜欢的电影的海报保存下来,以便日后欣赏或分享。但是,手动一个一个点击电影,然后下载海报显然是一项枯燥的任务。

    好在有Python这个强大的工具,你可以编写一个简单的脚本,自动爬取豆瓣电影Top250的电影海报,将它们保存到你的电脑上。这不仅能够省时省力,还能够让你一次性获取所有电影的海报。接下来,我将向你展示如何使用Python来实现这一目标。

    步骤 1:导入必要的库

    首先,我们需要导入一些Python库,以便后续的操作。我们将使用requests库来发送HTTP请求,以获取豆瓣电影Top250的页面内容。此外,我们还将使用正则表达式(re库)来从页面中提取电影海报的信息。

    import requests
    import re

    步骤 2:设置请求头

    在发送HTTP请求之前,我们需要设置一些请求头,以模拟浏览器的请求,避免被豆瓣服务器拒绝访问。这是一种常见的做法,以确保我们的爬虫行为合法且不会被阻止。

    headers = {
        "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/115.0.0.0 Safari/537.36 Edg/115.0.1901.188"
    }

    步骤 3:爬取豆瓣电影Top250页面

    接下来,我们将编写代码来发送HTTP请求,获取豆瓣电影Top250的页面内容。豆瓣电影Top250的页面URL中包含了不同页数的数据,我们可以通过循环来遍历多个页面,获取更多电影信息。

    for i in range(0, 226, 25):
        url = f"https://movie.douban.com/top250?start={i}&filter="
        response = requests.get(url, headers=headers)

    在这个示例中,我们使用range函数生成了一系列不同页数的URL,每页包含25部电影。通过循环,我们可以逐页获取电影信息。

    步骤 4:使用正则表达式提取电影海报信息

    豆瓣电影Top250页面中包含了电影的信息,其中包括电影的海报URL。我们可以使用正则表达式来提取这些URL。以下是提取电影海报URL的代码示例:

    a = re.findall("<img width=\"100\" alt=\"(.*?)\"", response.text, re.S)
    for vbn in a:
        print(vbn)

    在这段代码中,我们使用re.findall函数来查找页面中与正则表达式"<img width=\"100\" alt=\"(.*?)\""匹配的内容。这个正则表达式用于匹配电影海报的URL。然后,我们将提取到的海报URL打印出来。

    完整代码

    下面是整个爬取豆瓣电影Top250电影海报的完整代码:

    import requests
    import re
    
    headers = {
        "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/115.0.0.0 Safari/537.36 Edg/115.0.1901.188"
    }
    
    for i in range(0, 226, 25):
        url = f"https://movie.douban.com/top250?start={i}&filter="
        response = requests.get(url, headers=headers)
        a = re.findall("<img width=\"100\" alt=\"(.*?)\"", response.text, re.S)
        for vbn in a:
            print(vbn)

    结语

    通过这个简单的Python脚本,你可以轻松地爬取豆瓣电影Top250的电影海报信息,而不需要手动一个一个点击下载。这个技巧不仅可以用于获取电影海报,还可以用于爬取其他类型的信息,只需稍作修改即可。

    通过本教程,你已经学会了如何使用Python编写一个简单的爬虫脚本,用于获取豆瓣电影Top250的电影海报信息。这个技巧可以帮助你节省时间,快速获取感兴趣的电影海报,同时也是学习Python网络爬虫的一个有趣的项目。希望你能够充分利用这个方法,获取更多有用的数据!

  • 自动获取Steam限时免费游戏信息并实时推送教程

    假设你是一位热爱玩游戏的玩家,而且还热衷于追踪Steam平台上的限时免费游戏优惠。你不想错过任何一个免费游戏的机会,因此你希望能够及时获取到这些信息,并在游戏免费期间立刻领取。但是,为了获取这些信息,你不得不经常访问Steam网站,查找相关页面,非常繁琐。那么,有没有一种方法可以自动获取Steam限时免费游戏信息,并实时推送给你呢?

    幸运的是,我们可以使用Python来实现这个目标。本教程将教你如何编写一个Python脚本,可以自动爬取Steam网站上的限时免费游戏信息,并通过消息推送的方式将这些信息实时发送给你,以便你不会错过任何一个免费游戏的机会。

    步骤 1:导入必要的库

    首先,我们需要导入一些Python库,以便后续的操作。我们将使用requests库来发送HTTP请求,以获取Steam网站的页面内容。此外,我们还将使用BeautifulSoup库来解析HTML页面。

    import requests
    from bs4 import BeautifulSoup

    步骤 2:定义消息推送函数

    在这个步骤中,我们将定义一个消息推送函数,用于将限时免费游戏的信息发送给你。在本例中,我们将使用PUSHPLUS来实现消息推送。你需要注册一个PUSHPLUS账户,并创建一个推送通道,以获取一个Token。将这个Token替换为下面代码中的your_token

    def pushplus(_item, _message):
        token = 'your_token_here'  # 替换为你的PUSHPLUS Token
        api = 'http://www.pushplus.plus/send'
        _d = {
            "token": token,
            "title": _item,
            "content": _message
        }
        req = requests.post(api, data=_d)

    步骤 3:爬取Steam限时免费游戏信息

    接下来,我们将编写代码来爬取Steam网站上的限时免费游戏信息。我们将使用steamstats.cn这个网站作为示例,该网站提供了Steam限时免费游戏的信息。

    url = 'https://steamstats.cn/xi'
    headers = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.72 Safari/537.36 Edg/90.0.818.41'
    }
    
    r = requests.get(url, headers=headers)
    r.raise_for_status()
    r.encoding = r.apparent_encoding
    soup = BeautifulSoup(r.text, "html.parser")
    tbody = soup.find('tbody')

    在这个代码段中,我们首先指定了Steam限时免费游戏信息的URL,并设置了请求头,以模拟浏览器发送请求。然后,我们使用requests库发送HTTP GET请求,并获取响应内容。接下来,我们使用BeautifulSoup库将HTML页面解析为一个树状结构,并找到包含游戏信息的<tbody>标签。

    步骤 4:解析游戏信息并推送消息

    现在,我们已经找到了包含限时免费游戏信息的HTML元素,接下来需要解析这些信息并将其推送给你。

    desp = "?当前可领限时免费游戏?" + '\n'
    if tbody is not None:
        tr = tbody.find_all('tr')
        i = 1
        for tr in tr:
            # 解析每一行游戏信息
            td = tr.find_all('td')
            name = td[1].string.strip().replace('\n', '').replace('\r', '')
            gametype = td[2].string.replace(" ", "").replace('\n', '').replace('\r', '')
            start = td[3].string.replace(" ", "").replace('\n', '').replace('\r', '')
            end = td[4].string.replace(" ", "").replace('\n', '').replace('\r', '')
            time = td[5].string.replace(" ", "").replace('\n', '').replace('\r', '')
            oringin = td[6].find('span').string.replace(" ", "").replace('\n', '').replace('\r', '')
            sp = str(td[6]).split('"')
            http = sp[3]
    
            # 构建游戏信息字符串
            desp = desp + "序号:" + str(i) + '\n' + "游戏名称:" + name + '\n' + "类型:" + gametype + '\n' + "开始时间:" + start + '\n' + "结束时间:" + end + '\n' + "是否永久:" + time + '\n' + "平台:" + oringin + '\n' + "链接:" + http + '\n'
            i = i + 1
        else:
            desp = desp + "无"

    在这个代码段中,我们遍历了每一行限时免费游戏的信息,并使用BeautifulSoup提供的方法解析每个单元格的内容。然后,我们构建了一个包含游戏信息的字符串desp

    步骤 5:消息推送

    最后,我们调用之前定义的pushplus函数,将限时免费游戏的信息推送给你。

    pushplus("?今日喜加一?", desp)

    完整代码

    下面是整个自动获取Steam限时免费游戏信息并实时推送的代码的完整版:

    import requests
    from bs4 import BeautifulSoup
    
    def pushplus(_item, _message):
        token = 'your_token
    
    _here'  # 替换为你的PUSHPLUS Token
        api = 'http://www.pushplus.plus/send'
        _d = {
            "token": token,
            "title": _item,
            "content": _message
        }
        req = requests.post(api, data=_d)
    
    url = 'https://steamstats.cn/xi'
    headers = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.72 Safari/537.36 Edg/90.0.818.41'
    }
    
    r = requests.get(url, headers=headers)
    r.raise_for_status()
    r.encoding = r.apparent_encoding
    soup = BeautifulSoup(r.text, "html.parser")
    tbody = soup.find('tbody')
    
    desp = "?当前可领限时免费游戏?" + '\n'
    if tbody is not None:
        tr = tbody.find_all('tr')
        i = 1
        for tr in tr:
            # 解析每一行游戏信息
            td = tr.find_all('td')
            name = td[1].string.strip().replace('\n', '').replace('\r', '')
            gametype = td[2].string.replace(" ", "").replace('\n', '').replace('\r', '')
            start = td[3].string.replace(" ", "").replace('\n', '').replace('\r', '')
            end = td[4].string.replace(" ", "").replace('\n', '').replace('\r', '')
            time = td[5].string.replace(" ", "").replace('\n', '').replace('\r', '')
            oringin = td[6].find('span').string.replace(" ", "").replace('\n', '').replace('\r', '')
            sp = str(td[6]).split('"')
            http = sp[3]
    
            # 构建游戏信息字符串
            desp = desp + "序号:" + str(i) + '\n' + "游戏名称:" + name + '\n' + "类型:" + gametype + '\n' + "开始时间:" + start + '\n' + "结束时间:" + end + '\n' + "是否永久:" + time + '\n' + "平台:" + oringin + '\n' + "链接:" + http + '\n'
            i = i + 1
        else:
            desp = desp + "无"
    
    pushplus("?今日喜加一?", desp)

    结语

    通过这个自动获取Steam限时免费游戏信息并实时推送的Python脚本,你可以轻松地获取最新的游戏优惠信息,并确保不错过任何一个免费游戏的机会。这个脚本展示了如何使用Python的requests库和BeautifulSoup库来爬取网页内容,以及如何使用消息推送服务将信息实时发送给你。

    通过本教程,你已经学会了如何使用Python编写一个自动获取Steam限时免费游戏信息并实时推送的脚本。这个技巧不仅对游戏爱好者有用,还可以作为学习Python网络爬虫和消息推送的一个实际项目。希望你能够充分利用这个方法,及时获取到最新的游戏优惠信息!

  • 为你的Python项目自动安装依赖库:让你的代码自己动手装

    你是否曾经遇到过这样的情况:你在开发一个Python项目,但是随着项目的增长,你需要不断地添加新的依赖库(也就是Python的第三方模块),以便实现各种功能。当你将你的项目分享给其他人或部署到不同的环境时,你必须确保这些依赖库也已经安装,否则你的代码将无法正常运行。

    有一天,你决定分享你的项目给一个朋友,你很自信地告诉他只需运行你的代码,一切都会自动完成。但是,当你的朋友尝试运行代码时,却发现他必须手动安装一大堆依赖库,这让整个过程变得相当繁琐。你感到有点尴尬,因为你之前并没有考虑到这个问题。

    现在,让我们来解决这个问题。我将向你介绍一个简单而有效的方法,可以自动检测和安装Python项目所需的依赖库。这将使你的项目更加用户友好,减少了其他人使用你的代码时的不便。

    如何解决这个问题?

    解决这个问题的思路非常简单:我们可以编写一个Python脚本,让它扫描你的项目代码,找出项目中所使用的所有依赖库,并自动安装这些依赖库。这样,当其他人或你自己需要运行项目时,只需运行这个脚本,所有依赖库都会被自动安装,而无需手动操作。

    下面,我将向你介绍如何编写这个依赖库自动安装脚本,并将其分为几个步骤。

    步骤 1:寻找项目中的Python文件

    首先,我们需要找到你的项目中的所有Python文件。这些文件包括.py和.pyw文件,它们是Python代码的扩展名。

    import os
    
    def dir_files(directory, extension):
        """遍历目录内指定后缀"""
        file_list = []
        for root, dirs, files in os.walk(directory):
            for file in files:
                if file.endswith(extension):
                    if "tempCodeRunnerFile" not in file:  # CodeRunner生成的临时文件忽略掉
                        file_list.append(os.path.join(root, file))
        return file_list
    
    # 指定项目文件夹路径
    python_file_folders = [r"E:\Backup\脚本", r"E:\管理系统", r"E:\桌面文件"]
    
    # 查找项目中的Python文件
    python_files = []
    for folder in python_file_folders:
        python_files += dir_files(folder, ".py") + dir_files(folder, ".pyw")
    
    print("找到的Python文件:", python_files)

    在这个步骤中,我们使用了os库的os.walk函数来遍历指定目录下的所有文件和子目录。然后,我们筛选出扩展名为.py和.pyw的文件,并将它们的路径存储在python_files列表中。

    步骤 2:解析Python文件中的依赖库

    接下来,我们需要分析每个Python文件,找出它们所导入的依赖库。我们将使用Python的ast(抽象语法树)模块来解析代码文件。

    import ast
    
    def parse_imports(filename):
        """解析python源文件import了哪些库"""
        with open(filename, "r", encoding="utf-8") as f:
            tree = ast.parse(f.read())
        imports = set()
        for node in ast.iter_child_nodes(tree):
            if isinstance(node, ast.Import):
                for alias in node.names:
                    imports.add(alias.name.split(".")[0])
            elif isinstance(node, ast.ImportFrom):
                module_name = node.module.split(".")[0] if node.module else ""
                for alias in node.names:
                    imports.add(module_name + "." + alias.name.split(".")[0])
    
        return list(imports)
    
    # 解析Python文件中的依赖库
    all_imports = []
    for python_file in python_files:
        imports = parse_imports(python_file)
        all_imports += [library.split(".")[0] for library in imports]
    
    print("项目中使用的依赖库:", all_imports)

    在这个步骤中,我们首先打开每个Python文件,然后使用ast.parse函数将其内容解析为抽象语法树。接下来,我们遍历抽象语法树,找出所有的ImportImportFrom节点,这些节点包含了导入的依赖库信息。最后,我们将依赖库的名称提取出来,并存储在all_imports列表中。

    步骤 3:自动安装依赖库

    现在,我们已经知道了项目中使用的所有依赖库,接下来就是自动安装它们。我们可以使用Python的subprocess库来执行pip install命令,以安装这些依赖库。

    import subprocess
    
    def pip_install(libraries):
        """判断是否安装了库 没有就直接pip安装"""
        for library in libraries:
            library = library.split(".")[0]
            try:
                __import__(library)
            except ImportError:
                print(f"{library} 没有安装,正在使用pip安装...")
                subprocess.call(["pip", "install", library])
    
    # 自动安装依赖库
    if all_imports:
        imports = set(all_imports)
        pip_install(imports)

    在这个步骤中,我们定义了一个pip_install函数,它会检查每个依赖库是否已经安装,如果没有安装就使用subprocess.call来执行pip install命令进行安装。

    整脚本

    下面是整个自动安装依赖库的脚本的完整代码:

    import os
    import ast
    import subprocess
    
    def dir_files(directory, extension):
        """遍历目录内指定后缀"""
        file_list = []
        for root, dirs, files in os.walk(directory):
            for file in files:
                if file.endswith(extension):
                    if "tempCodeRunnerFile" not in file:  # CodeRunner生成的临时文件忽略掉
                        file_list.append(os.path.join(root, file))
        return file_list
    
    def parse_imports(filename):
        """解析python源文件import了哪些库"""
        with open(filename, "r", encoding="utf-8") as f:
            tree = ast.parse(f.read())
        imports = set()
        for node in ast.iter_child_nodes(tree):
            if isinstance(node, ast.Import):
                for alias in node.names:
                    imports.add(alias.name.split(".")[0])
            elif isinstance(node, ast.ImportFrom):
                module_name = node.module.split(".")[0] if node.module else ""
                for alias in node.names:
                    imports.add(module_name + "." + alias.name.split(".")[0])
    
        return list(imports)
    
    def pip_install(libraries):
        """判断是否安装了库 没有就直接pip安装"""
        for library in libraries:
            library = library.split(".")[0]
            try:
                __import__(library)
            except ImportError:
                print(f"{library} 没有安装,正在使用pip安装...")
                subprocess.call(["pip", "install", library])
    
    if __name__ == "__main__":
        # 指定项目文件夹路径
        python_file_folders = [r"E:\Backup\脚本", r"E:\管理系统", r"E:\桌面文件"]
    
        # 查找项目中的Python文件
        python_files = []
        for folder in python_file_folders:
            python_files += dir_files(folder, ".py") + dir_files(folder, ".pyw")
    
        print("找到的Python文件:", python_files)
    
        # 解析Python文件中的依赖库
        all_imports = []
        for python_file in python_files:
            imports = parse_imports(python_file)
            all_imports += [library.split(".")[0] for library in imports]
    
        print("项目中使用的依赖库:", all_imports)
    
        # 自动安装依赖库
        if all_imports:
            imports = set(all_imports)
            pip_install(imports)

    结语

    通过这个简单的自动安装依赖库的脚本,你可以使你的Python项目更加易于分享和部署。不再需要手动安装依赖库,只需运行这个脚本,一切都会自动完成。这不仅提高了代码的可移植性,还可以减少其他人或你自己在使用你的代码时的不便。

    希望这篇教程对你有所帮助,让你的Python项目更加智能化,让代码自己动手装依赖库!

  • 自动学籍照片裁剪工具:一键裁剪满足规格的学籍照片

    学校、培训机构、教育部门等经常需要处理大量学生或员工的学籍照片。这些照片通常需要符合特定的规格,包括尺寸和头像的居中等要求。手动裁剪这些照片是一项繁琐的任务,但我们可以使用Python编写一个自动化工具来简化这个过程。在本教程中,我们将介绍如何使用Python和一些强大的图像处理库来创建一个自动学籍照片裁剪工具。

    开篇故事

    假设你是一名学校管理员,你每年都需要处理大批学生的学籍照片。这些照片来自各种来源,尺寸和质量各不相同。你发现手动裁剪这些照片非常费时费力,而且容易出错。你希望有一种简单的方式来自动化这个任务,以节省时间和精力。好在你学习了Python编程,你决定创建一个自动学籍照片裁剪工具,让这项任务变得轻松而高效。

    准备工作

    在开始编写代码之前,我们需要准备一些工具和库。首先,确保你已经安装了Python。此外,我们将使用以下库来完成这个项目:

    • OpenCV:一个强大的计算机视觉库,用于图像处理。
    • dlib:一个机器学习工具包,包含了人脸检测器。

    你可以使用以下命令来安装这些库:

    pip install opencv-python
    pip install dlib

    还需要准备一些学籍照片,放在一个文件夹中,以便后续处理。确保这些照片具有不同的尺寸和质量,以模拟实际情况。

    项目概览

    我们的自动学籍照片裁剪工具将具备以下功能:

    1. 自动检测学籍照片中的人脸。
    2. 以检测到的人脸为中心,将照片裁剪成规定尺寸的半身照片。
    3. 保存裁剪后的照片到指定文件夹。

    现在,让我们逐步创建这个工具。

    步骤 1:导入所需库

    首先,我们需要导入所需的Python库。这些库包括OpenCV、dlib和os。

    import cv2
    import dlib
    import os

    步骤 2:定义人脸检测和裁剪函数

    我们将创建一个函数来执行人脸检测和裁剪。该函数将接受输入照片的路径、输出照片的路径、目标尺寸和延伸比例作为参数。延伸比例用于确定裁剪框的大小,以便获得半身照片。

    def detect_face_and_half_body(input_image_path, output_image_path, target_size=(260, 320), extend_ratio=1.0):
        # 使用OpenCV加载图像
        image = cv2.imread(input_image_path)
    
        # 将图像转换为灰度图像,以加快人脸检测速度
        gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
    
        # 从Dlib加载人脸检测器模型
        face_detector = dlib.get_frontal_face_detector()
    
        # 在图像中检测人脸
        faces = face_detector(gray_image)
    
        if len(faces) > 0:
            # 假设图像中只有一个人脸(你可以修改代码来处理多个人脸)
            face = faces[0]
    
            # 获取人脸的边界框坐标
            x, y, w, h = face.left(), face.top(), face.width(), face.height()
    
            # 计算人脸的中心点
            center_x = x + w // 2
            center_y = y + h // 2
    
            # 计算
    
    半身图像的裁剪区域的坐标
            crop_width = int(w * (1 + extend_ratio))
            crop_height = int(h * (1 + extend_ratio))
            crop_x1 = max(0, center_x - crop_width // 2)
            crop_y1 = max(0, center_y - crop_height // 2)
            crop_x2 = min(center_x + crop_width // 2, image.shape[1])
            crop_y2 = min(center_y + crop_height // 2, image.shape[0])
    
            # 裁剪图像以获取半身图像
            half_body_image = image[crop_y1:crop_y2, crop_x1:crop_x2]
    
            # 将半身图像调整到目标尺寸
            resized_image = cv2.resize(half_body_image, target_size, interpolation=cv2.INTER_AREA)
    
            # 保存调整后的图像
            cv2.imwrite(output_image_path, resized_image)
    
            print(f"检测到人脸,半身图像已保存:{output_image_path}")
        else:
            print(f"未在图像中检测到人脸:{input_image_path}")

    在这个函数中,我们首先加载输入图像并将其转换为灰度图像,以加快人脸检测速度。然后,我们使用Dlib库中的人脸检测器来检测图像中的人脸。

    如果检测到人脸,我们假设图像中只有一个人脸,并计算出人脸的位置和大小。接下来,我们根据延伸比例计算出半身图像的裁剪区域,并将图像裁剪到这个区域。最后,我们将裁剪后的图像调整到目标尺寸并保存到指定的输出路径。

    步骤 3:批量处理照片

    现在我们已经定义了单张照片的处理函数,接下来我们将创建一个函数来批量处理一个文件夹中的所有照片。

    def batch_detect_face_and_half_body(input_folder, output_folder, target_size=(260, 320), extend_ratio=1.0):
        if not os.path.exists(output_folder):
            os.makedirs(output_folder)
    
        for filename in os.listdir(input_folder):
            if filename.lower().endswith(('.png', '.jpg', '.jpeg', '.gif')):
                input_image_path = os.path.join(input_folder, filename)
                output_image_path = os.path.join(output_folder, filename)
                detect_face_and_half_body(input_image_path, output_image_path, target_size, extend_ratio)

    这个函数将遍历输入文件夹中的所有照片文件,并调用我们之前定义的处理函数来处理每张照片。处理后的照片将保存在输出文件夹中。

    步骤 4:运行自动裁剪工具

    现在,我们已经完成了自动学籍照片裁剪工具的编写。要使用这个工具,只需调用batch_detect_face_and_half_body函数,并提供输入文件夹、输出文件夹、目标尺寸和延伸比例作为参数。

    if __name__ == "__main__":
        input_folder = "输入文件夹路径"  # 替换为你的输入文件夹路径
        output_folder = "输出文件夹路径"  # 替换为你的输出文件夹路径
        target_size = (260, 320)
        extend_ratio = 2.0  # 增大extend_ratio以获得更大范围的半身图像
    
        batch_detect_face_and_half_body(input_folder, output_folder, target_size, extend_ratio)

    现在你可以运行这个脚本,它将自动处理输入文件夹中的所有照片,并将裁剪后的照片保存在输出文件夹中。

    结语

    通过这个自动学籍照片裁剪工具,你可以轻松地处理大批学籍照片,确保它们符合规定的尺寸和格式。这个工具可以节省大量时间和精力,特别是在处理大量照片时。希望这个项目对你有所帮助,让你的工作更加高效!

  • 打造自己的音乐下载器:一键获取喜爱音乐的便捷工具

    音乐是生活的一部分

    音乐伴随着我们的生活,成为我们生命中不可或缺的一部分。无论是欢乐的时刻,还是寂寞的时候,音乐都能陪伴我们度过。然而,在享受音乐的同时,我们是否曾经遇到过这样的问题:想要下载自己喜欢的音乐,却不知道如何获取高质量的音乐文件?如果是的话,本教程将带你一窥如何使用Python创建自己的音乐下载器,让你轻松获取喜欢的音乐!

    步骤 1:准备工作

    在开始之前,确保你已经完成以下准备工作:

    • 安装了Python编程环境。
    • 安装了所需的Python库,包括Tkinter、Requests、Beautiful Soup、tkinter.messagebox、PySimpleGUI以及retrying。你可以使用以下命令来安装它们:
    pip install tkinter requests beautifulsoup4 PySimpleGUI retrying

    步骤 2:创建音乐下载器界面

    我们首先需要创建一个简单而实用的用户界面,用于输入音乐搜索关键词并显示搜索结果。以下是界面的主要组成部分:

    • 音乐搜索通道选择:你可以选择不同的音乐搜索通道,例如酷我、网易云、QQ音乐、酷狗等。

    • 搜索框:你可以在搜索框中输入歌曲名或歌手,然后点击搜索按钮。

    • 搜索结果表格:搜索结果将以表格形式显示,包括序号、歌手、歌曲和专辑等信息。

    • 下载按钮:你可以选择要下载的音乐,并点击下载按钮将音乐保存到本地。

    以下是Python代码中界面的创建部分:

    import tkinter as tk
    from tkinter import ttk
    import tkinter.messagebox as mes_box
    import webbrowser
    import requests
    from bs4 import BeautifulSoup
    from retrying import retry
    
    class MusicDownloader:
        def __init__(self, width=1000, height=600):
            self.ui_weight = width
            self.ui_height = height
            self.title = "音乐下载器"
            self.ui_root = tk.Tk(className=self.title)
            self.ui_url = tk.StringVar()
            self.ui_var = tk.IntVar()
            self.ui_var.set(1)
            self.show_result = None
            self.song_num = None
            self.response_data = None
            self.song_url = None
            self.song_name = None
            self.song_author = None
    
        def create_ui(self):
            # 创建UI界面的代码在这里
            pass
    
        def center_ui(self):
            # 窗口居中显示的代码在这里
            pass
    
        def main_loop(self):
            # 主循环的代码在这里
            pass
    
    if __name__ == '__main__':
        downloader = MusicDownloader()
        downloader.main_loop()

    在接下来的步骤中,我们将逐步填充这些方法,创建完整的音乐下载器界面。

    步骤 3:实现界面布局

    在这一步,我们将填充create_ui方法,实现界面的布局和各个控件的功能。以下是界面布局的代码:

    def create_ui(self):
        # 创建Frame空间
        frame_1 = tk.Frame(self.ui_root)
        frame_2 = tk.Frame(self.ui_root)
        frame_3 = tk.Frame(self.ui_root)
        frame_4 = tk.Frame(self.ui_root)
    
        # 创建菜单
        ui_menu = tk.Menu(self.ui_root)
        self.ui_root.config(menu=ui_menu)
        file_menu = tk.Menu(ui_menu, tearoff=0)
        ui_menu.add_cascade(label='菜单', menu=file_menu)
        file_menu.add_command(label='使用说明', command=lambda: webbrowser.open('www.baidu.com'))
        file_menu.add_command(label='关于作者', command=lambda: webbrowser.open('www.baidu.com'))
        file_menu.add_command(label='退出', command=self.ui_root.quit)
    
        # 创建控件
        choice_passageway = tk.Label(frame_1, text='请选择音乐搜索通道:', padx=10, pady=10)
        passageway_button_1 = tk.Radiobutton(frame_1, text='酷我', variable=self.ui_var, value=1, width=10, height=3)
        passageway_button_2 = tk.Radiobutton(frame_1, text='网易云', variable=self.ui_var, value=2, width=10, height=3)
        passageway_button_3 = tk.Radiobutton(frame_1, text='QQ音乐', variable=self.ui_var, value=3, width=10, height=3)
        passageway_button_4 = tk.Radiobutton(frame_1, text='酷狗', variable=self.ui_var, value=4, width=10, height=3)
        input_label = tk.Label(frame_2, text="请输入歌曲名或歌手:")
        entry_style = tk.Entry(frame_2, textvariable=self.ui_url, highlightcolor='Fuchsia', highlightthickness=1, width=35)
        label2 = tk.Label(frame_2, text=" ")
        search_button = tk.Button(frame_2, text="搜索", font=('楷体', 11), fg='Purple', width=2, height=1, command=self.search_music)
        label3 = tk.Label(frame_2, text=" ")
        columns = ("序号", "歌手", "歌曲", "专辑")
        self.show_result = ttk.Treeview(frame_3, height=20, show="headings", columns=columns)
        download_button = tk.Button(frame_4, text="下载", font=('楷体', 11), fg='Purple', width=6, height=1, padx=5, pady=5, command=self.download_music)
    
        # 布局控件
        frame_1.pack()
        frame_2.pack()
        frame_3.pack()
        frame_4.pack()
        choice_passageway.grid(row=0, column=0)
    
        passageway_button_1.grid(row=0, column=1)
        passageway_button_2.grid(row=0, column=2)
        passageway_button_3.grid(row=0, column=3)
        passageway_button_4.grid(row=0, column=4)
        input_label.grid(row=0, column=0)
        entry_style.grid(row=0, column=1)
        label2.grid(row=0, column=2)
        search_button.grid(row=0, column=3, ipadx=10, ipady=10)
        label3.grid(row=0, column=4)
        self.show_result.grid(row=0, column=4)
        download_button.grid(row=0, column=5)
    
        # 设置表头
        self.show_result.heading("序号", text="序号")
        self.show_result.heading("歌手", text="歌手")
        self.show_result.heading("歌曲", text="歌曲")
        self.show_result.heading("专辑", text="专辑")
    
        # 设置列
        self.show_result.column("序号", width=100, anchor='center')
        self.show_result.column("歌手", width=200, anchor='center')
        self.show_result.column("歌曲", width=200, anchor='center')
        self.show_result.column("专辑", width=300, anchor='center')

    以上代码中,我们使用tkinter库创建了一个用户界面,包括选择音乐搜索通道、输入搜索关键词、点击搜索按钮、显示搜索结果、以及下载音乐等功能。

    步骤 4:搜索音乐

    在这一步中,我们将填充search_music方法,实现搜索音乐的功能。根据用户选择的音乐搜索通道,我们将发送HTTP请求获取搜索结果,并在界面中显示搜索结果。以下是搜索音乐的代码:

    @retry(stop_max_attempt_number=5)
    def search_music(self):
        for item in self.show_result.get_children():
            self.show_result.delete(item)
        headers = {
            'accept': 'application/json, text/plain, */*',
            'accept-encoding': 'gzip, deflate',
            'accept-language': 'zh-CN, zh;q=0.9',
            'cache-control': 'no-cache',
            'Connection': 'keep-alive',
            'csrf': 'HH3GHIQ0RYM',
            'Referer': 'http://www.kuwo.cn/search/list?key=%E5%91%A8%E6%9D%B0%E4%BC%A6',
            'User-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/99.0.4844.51 Safari/537.36',
            'Cookie': '_ga=GA1.2.218753071.1648798611; _gid=GA1.2.144187149.1648798611; _gat=1; Hm_lvt_cdb524f42f0ce19b169a8071123a4797=1648798611; Hm_lpvt_cdb524f42f0ce19b169a8071123a4797=1648798611; kw_token=HH3GHIQ0RYM'
        }
        search_input = self.ui_url.get()
        if len(search_input) > 0:
            search_url = 'http://www.kuwo.cn/api/www/search/searchMusicBykeyWord?'
            search_data = {
                'key': search_input,
                'pn': '1',
                'rn': '80',
                'httpsStatus': '1',
                'reqId': '858597c1-b18e-11ec-83e4-9d53d2ff08ff'
            }
            try:
                self.response_data = requests.get(search_url, params=search_data, headers=headers, timeout=20).json()
                songs_data = self.response_data['data']['list']
                if int(self.response_data['data']['total']) <= 0:
                    mes_box.showerror(title='错误', message='搜索: {} 不存在.'.format(search_input))
                else:
                    for i in range(len(songs_data)):
                        self.show_result.insert('', i, values=(i + 1, songs_data[i]['artist'], songs_data[i]['name'], songs_data[i]['album']))
            except TimeoutError:
                mes_box.showerror(title='错误', message='搜索超时,请重新输入后再搜索!')
        else:
            mes_box.showerror(title='错误', message='未输入需查询的歌曲或歌手,请输入后搜索!')

    在这段代码中,我们使用requests库发送HTTP请求,获取音乐搜索结果,并将搜索结果显示在界面的表格中。

    步骤 5:获取下载链接

    一旦用户选择了要下载的音乐,我们需要获取下载链接,以便下载音乐文件。在这一步中,我们将填充get_song_url方法,实现获取下载链接的功能。以下是获取下载链接的代码:

    def get_song_url(self, event):
        for item in self.show_result.selection():
            item_text = self.show_result.item(item, "values")
            self.song_num = int(item_text[0])
        if self.song_num is not None:
            songs_data = self.response_data['data']['list']
            songs_req_id = self.response_data['reqId']
            song_rid = songs_data[self.song_num - 1]['rid']
            music_url = 'http://www.kuwo.cn/api/v1/www/music/playUrl?mid={}&type=convert_url3&httpsStatus=1&reqId={}'.format(song_rid, songs_req_id)
            response_data = requests.get(music_url).json()
            self.song_url = response_data['data'].get('url')
            self.song_name = songs_data[self.song_num - 1]['name']
            self.song_author = songs_data[self.song_num - 1]['artist']
        else:
            mes_box.showerror(title='错误', message='未选择要下载的歌曲,请选择')

    在这段代码中,我们解析用户在界面中选择的音乐,并通过HTTP请求获取下载链接。

    步骤 6:下载音乐

    最后一步是实现下载音乐的功能。在这一步中,我们将填充download_music方法,实现将音乐文件下载到本地的功能。以下是下载音乐的代码:

    def download_music(self):
        if not os.path.exists('./music'):
            os.mkdir("./music/")
        if self.song_num is not None:
            song_name = self.song_name + '--' + self.song_author + ".mp3"
            try:
                save_path = os.path.join('./music/
    
    {}'.format(song_name)).replace('\\', '/')
                true_path = os.path.abspath(save_path)
                resp = requests.get(self.song_url)
                with open(save_path, 'wb') as file:
                    file.write(resp.content)
                    mes_box.showinfo(title='下载成功', message='歌曲:%s,保存地址为%s' % (self.song_name, true_path))
            except Exception:
                mes_box.showerror(title='错误', message='未找到存放歌曲的文件夹')
        else:
            mes_box.showerror(title='错误', message='未选择要下载的歌曲,请选择后下载')

    这段代码会将选择的音乐下载到名为./music/的文件夹中,并在下载完成后显示下载成功的提示信息。

    步骤 7:运行音乐下载器

    一切准备就绪,现在可以运行我们的音乐下载器了。运行以下代码:

    if __name__ == '__main__':
        downloader = MusicDownloader()
        downloader.main_loop()

    你将看到一个漂亮的音乐下载器界面,可以用它来搜索、选择并下载你喜欢的音乐。

    结语

    通过这个简单的音乐下载器,你可以方便地搜索、选择和下载你喜欢的音乐,而不必费心去寻找下载链接。这个项目还有很大的扩展空间,你可以进一步优化界面、增加更多音乐搜索通道、支持批量下载等功能。希望这个项目能够帮助你更好地享受音乐!

  • 使用Python编写小说章节批量下载器

    在本教程中,我们将学习如何使用Python编写一个小说章节批量下载器。这个工具可以帮助你下载小说的所有章节并保存为文本文件,以便离线阅读。我们将使用Python的Requests库来获取网页内容,Beautiful Soup库来解析HTML,以及多线程技术来提高下载速度。

    步骤 1: 准备工作

    在开始之前,确保你已经完成以下准备工作:

    • 安装了Python编程环境。
    • 安装了Requests库和Beautiful Soup库。你可以使用以下命令来安装它们:
    pip install requests beautifulsoup4

    步骤 2: 代码实现

    下面是我们的小说章节批量下载器的Python代码。请将它保存为一个Python脚本(例如 novel_downloader.py)。

    import os
    import requests
    import re
    import threading
    import time
    from bs4 import BeautifulSoup
    
    # 初始化变量和目录
    url_list = []
    headers = {
        "User-Agent": "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/50.0.2661.87 Safari/537.36"
    }
    directory = "txt"  # 存储文本文件的目录
    
    if not os.path.exists(directory):
        os.makedirs(directory)
    
    # 获取章节列表
    def get_chapter_list(book_id):
        # 在这里实现获取章节列表的代码,返回一个章节URL列表
        pass
    
    # 下载章节内容并保存到文件
    def download_chapter(chapter_url, lock):
        # 在这里实现下载章节内容并保存到文件的代码
        pass
    
    # 主函数
    def main():
        book_id = input("请输入小说的书籍ID: ")
        chapter_list = get_chapter_list(book_id)
    
        if not chapter_list:
            print("无法获取章节列表。请检查书籍ID或网络连接。")
            return
    
        print(f"共有 {len(chapter_list)} 章节需要下载。")
    
        num_threads = int(input("请输入线程数(推荐 5-10): "))
    
        # 将章节列表分割成多个子列表,每个子列表由一个线程处理
        chunk_size = len(chapter_list) // num_threads
        chapter_chunks = [chapter_list[i:i + chunk_size] for i in range(0, len(chapter_list), chunk_size)]
    
        # 创建线程锁
        lock = threading.Lock()
    
        # 启动多线程下载
        threads = []
        for chunk in chapter_chunks:
            thread = threading.Thread(target=download_chapter, args=(chunk, lock))
            thread.start()
            threads.append(thread)
    
        # 等待所有线程完成
        for thread in threads:
            thread.join()
    
        print("下载完成!所有章节已保存在 'txt' 目录下。")
    
    if __name__ == "__main__":
        main()

    步骤 3: 代码解释

    现在让我们解释上面代码的主要部分:

    1. 我们导入了必要的库,包括Requests库和Beautiful Soup库,以及其他一些标准库。

    2. 初始化一些变量,包括存储章节URL的列表 (url_list) 和请求头 (headers)。我们还指定了一个保存文本文件的目录 (directory)。

    3. get_chapter_list(book_id)函数负责获取小说的章节列表。在这个函数中,你需要实现获取章节列表的代码,并返回一个章节URL列表。

    4. download_chapter(chapter_url, lock)函数用于下载章节内容并保存到文件。在这个函数中,你需要实现下载章节内容并保存到文件的代码。

    5. main()函数是程序的入口点。它首先获取用户输入的书籍ID,然后调用get_chapter_list函数获取章节列表。接着,它将章节列表分割成多个子列表,每个子列表由一个线程处理。最后,它创建线程锁,启动多线程下载,并等待所有线程完成。

    步骤 4: 运行程序

    要运行这个小说章节批量下载器,只需执行以下步骤:

    1. 打开终端或命令提示符。

    2. 进入包含代码文件的目录。

    3. 运行代码:python novel_downloader.py

    程序将提示你输入小说的书籍ID和线程数,然后开始下载小说的所有章节。下载完成后,你将在 txt 目录下找到每个章节的文本文件。

    总结

    这个小说章节批量下载器是一个实用的工具,可以帮助你轻松获取小说的所有章节内容并保存为文本文件,方便离线阅读。通过多线程技术,下载速度得到显著提高。希望这个教程对你有所帮助!

  • 为你的办公室选择一台舒适的显示器:从同事的选择中汲取经验

    在如今数字化的工作环境中,显示器是我们日常工作不可或缺的一部分。但是,如果你在公司使用的显示器让你感到眼睛不适,那么可能是时候考虑换一台了。这篇文章将向你介绍一些同事在公司使用的显示器类型,以便你可以更好地了解如何选择一台适合自己的显示器,从而提高工作效率和舒适度。

    开篇故事

    你是否曾经坐在办公室的桌前,对着显示器感到不适?眼睛干涩、头痛或视觉疲劳可能都是因为你的显示器不适合你的需求。这是一个常见的问题,但好消息是,你并不孤单。让我们来听听一些同事们的经验,看看他们在公司使用的显示器类型是什么,以及他们是否有一些有用的建议。

    了解同事们的选择

    1. AOC 24寸 1080p

    同事AoEiuV020JP使用的是一台AOC 24寸 1080p显示器。这似乎是一个标准的普通显示器,适合一般办公使用。他提到虽然想换一台,但担心不支持HDMI接口可能会增加CPU的负担。

    2. DELL U2520D

    Tumblr同事在公司使用两台DELL U2520D显示器,它们支持100%缩放。虽然这些显示器不错,但对于习惯了家里的4K显示器的他来说,公司的2K显示器似乎不够细腻。

    3. 三星贴牌 23寸 1080p

    libook同事在家使用2K显示器和4K电视,但在公司配备的是一台三星贴牌的23寸1080p显示器。他认为虽然不是很出色,但用来处理文书还算凑合。

    4. Dell P2314H

    totoro625同事使用Dell P2314H显示器,虽然他的笔记本支持2.5K分辨率,但在公司他主要使用这台显示器,因为大家都使用同款。

    5. 24寸 4K

    anoninz同事推荐了一款24寸4K显示器,他认为性价比很高。这款显示器可能是一个不错的选择,尤其是如果你需要高分辨率。

    6. LG 4K显示器

    leehomyhh同事使用了一款LG的4K显示器已经有一段时间了,他觉得性能还不错,价格也相对合理。

    7. Philips 27寸 4K

    thunderstormhit同事在公司使用两台飞利浦27寸4K显示器和一台Dell 24寸1080p显示器。虽然他认为Dell显示器一般,但并不影响他的工作效率。

    8. SANC T5rpo 2K 75Hz

    Amber2011同事在公司使用一台SANC T5rpo 2K 75Hz显示器,他觉得这个显示器一般,不好也不坏。而在家里,他使用LG 27UP850N-W 4K 60Hz,感觉还不错。

    9. 27寸 5K

    yty2012g同事则在家使用一台淘宝山寨的27寸5K显示器,这显示器可能是一些人追求高分辨率的好选择。

    10. 23寸 4K

    CloudnuY同事采用了一种咸鱼组装的方式,使用了一台23寸4K显示器。这也是一种有趣的选择。

    11. 垃圾Dell显示器

    最后,en20同事提到公司使用的Dell 1080p显示器不太理想,有明显的锯齿和色差。但他习惯了,不打算自己花钱升级配置。

    如何选择适合自己的显示器?

    通过了解同事们的选择,你可能已经有了一些灵感,但如何选择适合自己的显示器呢?以下是一些考虑因素:

    1. 分辨率

    分辨率是显示器性能的重要指标。如果你需要处理高分辨率的图像或视频,那么选择4K显示器可能是个不错的选择。如果只是办公应用,2K或1080p可能已经足够了。

    2. 大小

    显示器的大小也很重要。大尺寸的显示器可以提高工作效率,但也需要更多的桌面空间。考虑你的工作环境和桌面空间,选择一个合适的大小。

    3. 护眼功能

    一些显示器具有护眼功能,可以减少蓝光辐射,降低眼睛疲劳。如果你长时间使用显示器,这可能是一个重要考虑因素。

    4. 接口

    确保显示器的接口与你的电脑兼容。常见的接口包括HDMI、DisplayPort和USB-C。

    5. 品牌和质量

    选择知名品牌的显示器通常更可靠,质量更高。阅读用户评价和专业评测可以帮助你选择一台质量可靠的显示器。

    6. 预算

    最后,考虑你的预算。显示器的价格范围很广,根据你的预算选择最合适的显示器。

    结论

    在选择办公室显示器时,不同的人有不同的需求和偏好。了解你自己的需求,并参考同事的选择,可以帮助你找到一台适合自己的显示器,提高工作效率和舒适度。

    通过考虑分辨率、大小、护眼功能、接口、品牌和预算等因素,你可以做出明智的选择,让工作变得更加愉快。

  • 如何设计延伸集群网络:确保高效通信与故障容忍性

    在今天的科技世界中,网络设计是任何企业或组织的核心要素之一。特别是在云计算和虚拟化技术的兴起下,网络必须不仅具备高效通信的能力,还要确保在出现故障时能够保持可用性。本教程将向您介绍如何设计一个优质的延伸集群网络,以满足这些需求。

    开篇故事:解锁网络设计的魔法

    让我们从一个有趣的场景开始。假设您是一家跨国公司的网络管理员,负责管理位于不同地理位置的数据中心。您的公司依赖于虚拟化技术来运行业务,并希望确保数据中心之间的通信畅通无阻。同时,您也要考虑到可能出现的故障情况,以保障业务的连续性。

    在这个挑战充满的网络设计任务中,您需要设计一个网络架构,使得延伸集群中的三个站点可以跨管理网络、vSAN网络、虚拟机网络和vMotion网络进行通信。接下来,我们将为您解锁网络设计的魔法,帮助您构建强大而稳定的延伸集群网络。

    网络要求与设计

    1. 管理网络

    在延伸集群中,管理网络是至关重要的。它需要跨所有三个站点进行连接,以便有效地管理和监控您的网络基础设施。您可以选择使用第2层延伸网络或第3层网络来实现这一连接。

    2. vSAN网络

    vSAN网络是支撑存储虚拟化的关键组成部分。在延伸集群中,vSAN网络需要跨所有三个站点进行连接,同时需要具备独立的路由和连接,以确保数据的可靠性。您可以在数据站点和见证主机之间使用第2层和第3层网络,而在数据站点之间使用第2层延伸网络或第3层网络。

    3. 虚拟机网络

    虚拟机网络用于虚拟机之间的通信,但需要注意的是,它需要在数据站点之间进行连接,而不是见证主机。您可以选择使用第2层延伸网络或第3层网络来实现这种连接。在设计虚拟机网络时,要确保即使出现故障,虚拟机也无需在远程站点上使用新的IP地址。

    4. vMotion网络

    vMotion网络用于虚拟机迁移,同样需要在数据站点之间进行连接,而不是见证主机。您可以选择使用第2层延伸网络或第3层网络来实现这一连接。

    静态路由的重要性

    在设计延伸集群网络时,静态路由是一个关键概念。静态路由允许您定义特定网络的访问路径,确保在所有主机之间的正常通信。对于vSAN网络,您可以添加静态路由以确保数据站点和见证主机之间的通信。

    考虑一个具体的情景,vSAN网络跨越了两个数据站点上的172.10.0.0广播域,而见证主机位于另一个广播域,例如172.30.0.0。如果数据站点上的VMkernel适配器尝试连接到见证主机上的vSAN网络,连接将失败,因为ESXi主机上的默认网关与管理网络相关联,而没有从管理网络到vSAN网络的路由。

    为解决这个问题,您可以在每个数据站点上的主机上添加静态路由,以便通过172.10.0.0接口路由访问172.30.0.0见证网络的请求。同时,也需要将静态路由添加到见证主机,以便通过172.30.0.0接口路由访问数据站点的172.10.0.0网络的请求。

    请注意,如果您使用静态路由,您必须手动为新添加到任何站点的ESXi主机添加静态路由,以确保它们能够跨集群进行通信。如果替换见证主机,还需要更新静态路由配置。

    配置静态路由的步骤

    以下是配置静态路由的基本步骤:

    1. 打开ESXi主机的命令行界面。

    2. 使用以下命令添加静态路由:

      esxcli network ip route add --gateway <网关地址> --network <目标网络地址>

      在上述命令中,<网关地址> 是要设置的网关地址,<目标网络地址> 是要路由的目标网络地址。

    3. 重复这些步骤,确保在每个数据站点上的主机和见证主机上都添加了相应的静态路由。

    结论

    通过合理的网络设计和静态路由配置,您可以构建一个强大而稳定的延伸集群网络,确保在数据中心之间实现高效通信和故障容忍性。这将使您的业务能够以可靠的方式运行,无论发生什么情况。

    希望这篇教程能够帮助您理解如何设计延伸集群网络,并为您的网络管理工作提供宝贵的指导。

  • 如何轻松利用 Inno Setup 制作Windows安装程序

    有一天,小张准备给自己的网站添加一个下载功能,提供自己开发的 Windows 程序给用户。但一个问题让他纠结:如何创建一个专业级别的安装程序呢?他试了好几款商业软件,但都嫌价格不菲。正当他快要放弃的时候,他发现了 Inno Setup——一个免费、专业、可定制的 Windows 安装程序制作工具。从此以后,小张成了 Inno Setup 的铁杆粉丝,并且他的用户也因为这个方便易用的安装程序而倍感高兴。

    今天,我就要给你们展示如何利用这个神奇的工具 Inno Setup,轻松制作出一个专业级别的安装程序。

    Inno Setup 一览

    不同于其他昂贵的商业解决方案,Inno Setup 是一个完全免费的安装程序制作工具,即使是用于商业应用也不例外。它提供了一个完善的特性集,包括对所有自2006年以来发布的 Windows 版本的支持,64位应用安装,以及高度可定制的设置选项。

    注意:虽然它是免费的,但并不意味着它是公有领域软件。确保你查看并遵守其授权协议。

    开始使用:下载与安装

    首先,去 Inno Setup 的官方网站下载软件并按照提示进行安装。

    st=>start: 开始
    op1=>operation: 访问 Inno Setup 官方网站
    op2=>operation: 下载软件安装包
    op3=>operation: 安装 Inno Setup
    e=>end: 完成安装
    
    st->op1->op2->op3->e

    制作你的第一个安装程序

    1. 启动 Inno Setup
    2. 选择 ‘New’ 开始一个新项目
    3. 按照向导的步骤完成设置

    这其中,你可以选择压缩方式,是否创建桌面或开始菜单快捷方式,以及是否修改注册表等。

    st=>start: 启动 Inno Setup
    op1=>operation: 选择 'New'
    op2=>operation: 按照向导完成设置
    op3=>operation: 保存并编译
    e=>end: 得到你的安装程序
    
    st->op1->op2->op3->e

    高级选项:Pascal 脚本

    Inno Setup 还支持使用 Pascal 脚本来进行更高级的定制。例如,你可以编写脚本来控制安装过程中的用户输入,或者在安装完成后自动打开你的应用程序。

    结语:不再烦恼,轻松安装

    多年前,创建一个看起来专业的安装程序可能需要你花费大量时间和金钱。但现在,有了 Inno Setup,一切都变得简单和高效了。它不仅拥有丰富的特性,而且完全免费。所以,何必再为创建一个出色的安装程序而烦恼呢?赶快行动,利用 Inno Setup 让你的应用程序更加专业吧!

  • 如何使用Python批量下载小红书图片

    你是否曾经浏览小红书(Red)上的一篇精彩笔记,想要将其中的图片保存到本地?或者你想批量下载某个小红书用户的所有图片?不用担心,本教程将向你展示如何使用Python编写一个简单但功能强大的脚本,来实现批量下载小红书图片的目标。

    1. 背景故事

    小红书是一个充满灵感和创意的社交平台,用户可以在上面分享各种生活笔记,包括美食、时尚、旅行等等。这些笔记通常包含大量高质量的图片,有时你可能会希望将这些图片保存到本地,以便离线查看或做其他用途。但手动下载每张图片会非常费时费力,因此我们编写了这个Python脚本,来帮助你自动完成这项任务。

    2. 准备工作

    在开始之前,确保你已经安装了Python,并安装了以下必要的库:requestsBeautifulSoup。你可以使用以下命令来安装它们:

    pip install requests beautifulsoup4

    3. 编写Python脚本

    下面是我们编写的Python脚本,它可以根据你的选择,批量下载小红书上的图片。

    import requests
    from bs4 import BeautifulSoup
    import os
    import re
    import json
    
    # 创建文件夹
    def mkdir(path):
        folder = os.path.exists(path)
        if not folder:
            print("--- 创建新的文件夹? ---")
            os.makedirs(path)
            print("--- OK ? ---")
        else:
            print("--- ⚠️ 文件夹已存在! ---")
    
    # 发起网络请求,获取网页源码
    def fetchUrl(url):
        headers = {
            'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 UBrowser/6.2.4098.3 Safari/537.36',
        }
        r = requests.get(url, headers=headers)
        return r.text
    
    # 解析html文本,提取无水印图片的url
    def parsing_link(html):
        soup = BeautifulSoup(html, 'html.parser')
        script = soup.find('script', string=re.compile('window\.__INITIAL_STATE__'))
        test = re.split(r'=', script.string)
        string = test[1].replace('undefined', 'null')
        result = json.loads(string, strict=False)
        imageList = result.get('note', {}).get('note', {}).get('imageList')
        title = result.get('note', {}).get('note', {}).get('title')
        if title == '':
            title = result.get('note', {}).get('note', {}).get('desc')
        title = sanitize_folder_name(title)
        if imageList and title:
            print('标题:', title)
            print('开始下载啦!?')
    
            file = os.path.dirname(__file__) + '/image/' + title
            mkdir(file)
    
            for i in imageList:
                picUrl = f"https://sns-img-qc.xhscdn.com/{i['traceId']}"
                yield picUrl, i['traceId'], title
    
    # 下载图片
    def download(url, filename, folder):
        headers = {
            'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 UBrowser/6.2.4098.3 Safari/537.36',
        }
        try:
            r = requests.get(url, headers=headers)
            content_type = r.headers.get('Content-Type')
            image_format = content_type.split('/')[-1]
    
            if image_format not in ['jpeg', 'png', 'gif', 'bmp']:
                image_format = 'jpeg'
    
            with open(f'image/{folder}/{filename}.{image_format}', 'wb') as v:
                v.write(r.content)
        except Exception as e:
            print('图片下载错误!')
    
    # 修正文件夹命名
    def sanitize_folder_name(name: str) -> str:
        name = re.sub(r'[<>:"/\\|?*]', '_', name)
        name = name.strip()
        if len(name) > 255:
            name = name[:255]
        return name
    
    # 主循环
    def roopLink(url):
        html = fetchUrl(url)
        traceId = 0
        for url, _, title in parsing_link(html):
            print(f"download image {url}")
            download(url, traceId, title)
            traceId += 1
    
    if __name__ == '__main__':
        choice = input("请输入选项 (1: 循环获取链接; 2: 获取文本地址并下载): ")
        if choice == '1':
            while True:
                links = input("请输入小红书的链接 (输入 'end' 结束程序): ")
                if links == 'end':
                    break
                roopLink(links)
        elif choice == '2':
            file_path = input("请输入文本文件地址(回车默认是1.txt): ")
            if file_path == '':
                file_path = '1.txt'
            with open(file_path, 'r') as f:
                links = f.read().splitlines()
            for link in links:
                roopLink(link)
    
        print("下载完成啦!?")

    4. 使用方法

    使用这个脚本非常简单,只需按照以下步骤操作:

    1. 运行脚本并选择你的操作类型(1或2)。
    2. 如果选择了1,输入小红书的链接并按照提示操作。
    3. 如果选择了2,输入包含小红书链接的文本文件的地址,并按照提示操作。
    4. 所有图片将会下载到脚本所在目录下的image文件夹中。

    现在,你可以轻松地批量下载小红书图片了!

    5. 安全性考虑

    请注意,使用这个脚本下载图片时,要遵守小红书的使用规定和法律法规。不要滥用脚本来侵犯他人的隐私或侵

    权。

    希望这个教程对你有所帮助,让你更方便地管理小红书上的精彩图片!

    免责声明:本教程仅用于教育和学习目的。请遵守相关网站的使用规定和法律法规,谨慎使用网络爬虫技术。