Python实现一键从Gitlab上拉取文件夹下多个项目代码到本地

公司Gitlab上有一个项目文件夹,下面有20多个Git项目,要把它们一个个拉取下来比较费时,所以用Python写了一个脚本。

脚本代码

python 复制代码
import requests
from git import Repo
import os

# GitLab地址
gitlab = "https://xxxx/api/v4/projects"

# token,在GitLab上面申请Access Token得到
token = "xxxx"

# 分页参数,一次性干他妈的50个,绝对查完
page = 1
per_page = 50

# 最后请求的url
url = "{}?private_token={}&page={}&per_page={}".format(gitlab, token, page, per_page)

# 项目存放地址
parentPath = "D:\\Projects\\MyPAth"

# 拉取代码后要切换的分支,是master就不用切换了
branch = "master"

def requestGitProjects():
    # 请求
    response = requests.get(url)

    # 记录每个项目文件夹下的项目数量,最后判断对不对
    backendCount = 0
    frameworkCount = 0
    mockCount = 0
    if response.status_code == 200:
        projects = response.json()
        for project in projects:
            # 得到git地址
            http_url = project["http_url_to_repo"]
            # 得到git项目名称
            name = project["path"]
            print(http_url)
            path = parentPath + "\\" + name
            # 去做Git操作
            gitPull(http_url, path)
        print("解析完成。")
    else:
        print("请求失败:", response.status_code)


def gitPull(gitUrl, path):
    if os.path.exists(path):
        print("文件夹已存在,跳过:", path)
        return
    # 拉代码和切换分支,异常说明没有内容或者没有分支,那就不管了
    try:
        repo = Repo.clone_from(gitUrl, path)
        if "master" != branch:
            repo.git.checkout(branch)
    except Exception as e:
        pass


# 执行代码
requestGitProjects()

Python环境准备

shell 复制代码
# 脚本代码路径
cd xxx

# 创建虚拟环境
python -m venv venv

# 激活虚拟环境,此处为Windows系统,如果是Linux则是二进制文件
\venv\Scripts\activate.bat

# 激活后则进入虚拟环境,安装所需要的依赖
(venv) pip install requests
(venv) pip install gitpython

# 运行代码
(venv) python demo.py
相关推荐
星星电灯猴34 分钟前
Thor 抓包工具详解 iOS 抓包方法、HTTPS 抓包难点与常见网络调试工具对比
后端
姓王者34 分钟前
可能解决Tauri多窗口应用阻塞问题
后端
RoyLin39 分钟前
TypeScript设计模式:抽象工厂模式
前端·后端·typescript
没逻辑1 小时前
Post-Quantum HTTPS:未来的安全通信架构
后端·安全
数据智能老司机1 小时前
精通 Python 设计模式——分布式系统模式
python·设计模式·架构
云中雾丽1 小时前
Redis 使用记录
后端
似水流年流不尽思念1 小时前
MongoDB 有哪些索引?适用场景?
后端·mongodb
MacroZheng1 小时前
横空出世!MyBatis-Plus 同款 ES ORM 框架,用起来够优雅!
java·后端·elasticsearch
武子康1 小时前
大数据-100 Spark DStream 转换操作全面总结:map、reduceByKey 到 transform 的实战案例
大数据·后端·spark
bobz9651 小时前
网段分配
后端