Python批量Git Pull,对文件夹批量进行Pull操作

效果展示

在这里插入图片描述

说明

  1. 本来是想写的完善一些,但由于是自用,所以写出来后发现已经解决了自己的问题,所有 2和3功能没有写。

  2. 执行的话,需要 cmd 之后 直接 Python BatchGitPull.py 运行下面代码即可。

  3. 里面同时涉及到其他Pyhon知识点(写给自己的,因为自己老记不住):
    1. 输入任意键退出控制台
    2. 控制台输出不同颜色
    3. 获取命令执行后的返回结果
    4. 根据不同的输入执行不同的代码
    5. 获取用户管理员权限,从而刷新系统DNS
    6. …

  4. 注意:is_admin 这个访问是来判断是否有管理员权限的,如果担心代码有问题,可以去掉管理员权限的相关代码。我是因为个人情况,不加的话,无法进行系统DNS的刷新,导致有时候梯子换了频道后,还是Pull不下来,所以出此下策。

具体代码

#!/usr/bin/python
# -*- coding:utf-8 -*-
import os
import time
import ctypes
import sys
import subprocess
import colorama
from colorama import Fore, Style


def is_admin():
    try:
        return ctypes.windll.shell32.IsUserAnAdmin()
    except:
        return False


dir_root = 'N:/Program Files/sd-webui-aki-v4.4/ComfyUI/ComfyUI/custom_nodes'


def PrintError(log):
    print(Fore.RED + log + Style.RESET_ALL)  # 红色


def PrintSuccess(log):
    print(Fore.GREEN + log + Style.RESET_ALL)  # 绿色


def BatchPull():
    dir_route = dir_root
    if os.path.exists(dir_route) == False:
        PrintError("没有这个文件夹 " + dir_root)
        return
    # 切换到test目录
    os.chdir(dir_route)
    current_directory = os.getcwd()
    dirs = os.listdir()
    # 定义git命令
    command = 'git pull'  # origin master'
    netCommand = 'ipconfig/flushdns'
    index = 0
    error_list = {}
    for code_dir in dirs:
        index += 1
        # 拼接路径(当前目录+代码目录)
        # os.system(netCommand)
        # 使用 subprocess.run
        result = subprocess.run(
            netCommand, stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True, shell=True)

        # 获取标准输出

        # 获取标准错误输出(如果有)
        if result.stderr:
            PrintError("网络错误输出:" + result.stderr)
        else:
            print("刷新网络成功!")  # + result.stdout)

        full_path = os.path.join(current_directory, code_dir)
        if os.path.isdir(full_path) == False:
            print("跳过:不是文件夹 " + full_path)
            continue
        os.chdir(full_path)
        print(str(index) + " : 进行 Pull " + code_dir)
        # os.system(command)
        result = subprocess.run(
            command, stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True, shell=True)

        waitTimer = 2
        # 获取标准错误输出(如果有)
        if result.stderr:
            waitTimer *= 2
            PrintError("错误输出:" + result.stderr)
            error_list[index] = code_dir
        else:
            PrintSuccess("完成输出:" + result.stdout)

        time.sleep(waitTimer)
        # print(code_dir + " Pull完毕! " + full_path + '\n')
        os.chdir(dir_route)

    if len(error_list) > 0:
        for err in error_list:
            PrintError("未完成列表:" + err + " : " + error_list[err])
    else:
        PrintSuccess("完美!全部更新成功!!")

    input("按回车键退出...")


project_addr = [
    'git@gitlab.com:project/mengxixing-h5.git',
    'git@gitlab.com:project/waterinbrainopendomain.git',
    'git@gitlab.com:project/waterinbrain.git'
]


def BatchClone():
    os.mkdir('E:/code')
    os.chdir('E:/code')
    command = 'git clone '
    for i in project_addr:
        os.popen(command + str(i))
        time.sleep(1)
        print(i + " Clone完毕!")

    print('当前项目组已全部拉取完毕')


# BatchPull()

if is_admin():
    # 初始化colorama
    colorama.init()

    PrintSuccess("测试")
    user_input = input("将对 \" " + dir_root + " \" 文件夹下所有子文件执行批量Git操作,请确定路径正确。\n\n" +
                       "请选择操作方式: \n1. 按1键 则全部执行Pull,获取最新代码。\n2. 按2键 则只执行Pull失败的库 " +
                       "\n3. 按3键 暂时未开发\n \n \n 注意:\n1. 只有当1键执行后才会有Pull错误数据,这时候2键才有效果\n2. 按键后,再按回车键来确定\n" +
                       "___________________________________________\n")

    if user_input == "1":

        BatchPull()
    elif user_input == "2":
        print("执行了B操作")
    elif user_input == "3":
        input("暂未任何操作,按回车键退出...")
    else:
        input("无效输入,按回车键退出...")

else:
    ctypes.windll.shell32.ShellExecuteW(
        None, "runas", sys.executable, " ".join(sys.argv), None, 1)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/208988.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

SSM项目实战-mapper实现

1、SysUserMapper.java package com.atguigu.schedule.mapper; import com.atguigu.schedule.pojo.SysUser; import org.springframework.stereotype.Repository; Repository public interface SysUserMapper {SysUser getSysUser(SysUser sysUser); }2、ScheduleMapper.java p…

“超越摩尔定律”,存内计算走在爆发的边缘

过去几十年来,在摩尔定律的推动下,处理器的性能有了显著提高。然而,传统的计算架构将数据的处理和存储分离开来,随着以数据为中心的计算(如机器学习)的发展,在这两个物理分离的单元之间传输数据…

3D云参观红色革命纪念馆允许更多人在线交流、体验

生活在和平年代的新一代青少年,可能对革命先烈英勇事迹难以有很深的体会,无法切实感受到中国共产党无畏牺牲、誓死保家卫国的红色精神,因此借助VR虚拟现实制作技术,让参观者们走近革命先烈中,感受老一辈无产阶级革命家…

YOLOv8 第Y7周 水果识别

1.创建文件夹: YOLOv8开源地址 -- ultralytics-main文件下载链接:GitHub - ultralytics/ultralytics: NEW - YOLOv8 🚀 in PyTorch > ONNX > OpenVINO > CoreML > TFLite 其余文件由代码生成。 数据集下载地址:Frui…

CF1877 E. Autosynthesis 基环树dp

传送门:CF [前题提要]:一道基环树dp,但是题目有点绕,当时卡了我整整半天,到了第二天换了和清醒的脑子然后和别人讨论才整明白,故记录一下 题目很绕,故不再介绍. 首先对于这种下标和值有关系的题目.其实不难想到建图(CF上有大量这种 t r i c k trick trick),随便举个类似的题…

HarmonyOs 4 (一) 认识HarmonyOs

目录 一 HarmonyOs 背景1.1 发展时间线1.2 背景分析1.2.1 新场景1.2.2 新挑战1.2.3 鸿蒙生态迎接挑战 二 HarmonyOS简介2.1 OpenHarmony2.2 HarmonyOS Connect2.3 HarmonyOS Next**2.4 ArkTS (重点掌握)****2.5 ArkUI** 三 鸿蒙生态应用核心技术理念**3.…

Gavin Wood:财库保守主义偏离了初心,应探索 Fellowship 等更有效的资金部署机制

波卡创始人 Gavin Wood 博士最近接受了 The Kusamarian 的采访,分享了他的过往经历、对治理的看法,还聊到了 AI、以太坊、女巫攻击、财库等话题。本文整理自 PolkaWorld 对专访编译的部分内容,主要包含了 Gavin 对治理、财库提案、生态资金分…

re:Invent大会,亚马逊云科技为用户提供端到端的AI服务

11月末,若是你降落在拉斯维加斯麦卡伦国际机场,或许会在大厅里看到一排排AI企业和云厂商相关的夸张标语。走向出口的路上,你的身边会不断穿梭过穿着印有“AI21Lab”“Anthropic”等字样的AI企业员工。或许,你还会被机场工作人员主…

PyQt基础_014_对话框类控件QFileDialog

基本操作 import sys from PyQt5.QtCore import * from PyQt5.QtGui import * from PyQt5.QtWidgets import *class filedialogdemo(QWidget):def __init__(self, parentNone):super(filedialogdemo, self).__init__(parent)layout QVBoxLayout()self.btn QPushButton("…

【Linux】cp 命令使用

cp 命令 cp(英文全拼:copy file)命令主要用于复制文件或目录。 著者 由Torbjorn Granlund、David MacKenzie和Jim Meyering撰写。 语法 cp [选项]... [-T] 源文件 目标文件或:cp [选项]... 源文件... 目录或:cp [选…

SpringBoot 集成 ChatGPT,实战附源码

1 前言 在本文中,我们将探索在 Spring Boot 应用程序中调用 OpenAI ChatGPT API 的过程。我们的目标是开发一个 Spring Boot 应用程序,能够利用 OpenAI ChatGPT API 生成对给定提示的响应。 您可能熟悉 ChatGPT 中的术语“提示”。在 ChatGPT 或类似语…

UDS诊断服务

UDS诊断服务 什么是UDS? UDS – Unified diagnostic services (统一诊断服务) 俗称14229. 形象的说:就是使用一套仪器,对当前汽车出现的问题进行分析。而这套仪器与汽车交谈所使用的语言就是UDS(不是唯一的方法)。 …

【Linux系统化学习】揭秘 命令行参数 | 环境变量

个人主页点击直达:小白不是程序媛 Linux专栏:Linux系统化学习 代码仓库:Gitee 目录 命令行参数 环境变量 PATH 查看PATH $PWD 查看环境变量PWD $HOME 查看系统支持的环境变量 获取环境变量 命令行参数 在C/C编程语言中我们有一个…

domjudge题目配置和开比赛

系统使用的是7.3.3,domjudge配置的方法请参考前文 domjudge配置-CSDN博客 题目导入 传统比较 首先可以去domjudge中随便下载一个题目,下载下来的压缩包应该是这样的 │ domjudge-problem.ini │ problem.pdf │ problem.yaml │ └─data└─sec…

西南科技大学(数据结构A)期末自测练习五

一、选择题(每空 1 分,共 5 分) 1、下面关于图的叙述中,正确的是( )。 (1).回路是简单路径 (2).存稀疏矩阵,用邻接矩阵比邻接表更省空间 (3).若有像图中存在…

网页开发 JS基础

目录 JS概述 基本语法 数据类型内置方法 DOM对象 查找标签 绑定事件 操作标签 jQuery 查找标签 绑定事件 操作标签 Ajax请求 数据接口 前后端分离 ajax的使用 JS概述 一门弱类型的编程语言,属于基于对象和基于原型的脚本语言. 1 直接编写<script>console…

numpy知识库:深入理解numpy的repeat函数和numpy数组的repeat方法

前言 numpy中的repeat函数顾名思义&#xff0c;可以将给定的数组沿着指定的轴重复多次&#xff0c;生成一个新的数组。但具体如何重复呢&#xff1f;本次博文就来探讨并试图回答这个问题&#xff0c;感兴趣的小伙伴可以继续阅读下去&#xff0c;希望对你有所启示~ numpy中的r…

Linux基本指令(后篇)

目录 14.时间指令date 15.Cal指令 16.find指令(非常重要) 17.grep指令 18.打包压缩指令zip和tar以及解压指令unzip和tar 14.时间指令date date(显示当前时间) 1.在显示方面&#xff0c;使用者可以设定欲显示的格式&#xff0c;格式设定为一个加号后接数个标记&#xff0c;其中…

企业存货库存综合分析全流程图

上期我们谈到了 诊断存货管理的4大维度&#xff0c;今天我们进一步全方位、全周期的分析企业内存货的问题。 企业存货是企业用于生产或销售的货品&#xff0c;是企业价值增值变现的载体&#xff0c;但是如果一旦没有产生交易&#xff0c;存货就很有可能带来损失。存货伴随着企业…

C#基础与进阶扩展合集-进阶篇(持续更新)

目录 本文分两篇&#xff0c;基础篇点击&#xff1a;C#基础与进阶扩展合集-基础篇 二、进阶扩展 1、Predicate 2、设置C#语言版本 3、ListCollectionView过滤集合 4、Adapt适配器 5、值类型与引用类型 6、程序设置当前项目工作目录 7、获取App.config配置文件中的值 …
最新文章