python 统计所有的 仓库 提交者的提交次数

news/2025/3/26 17:01:25/

字典去重 YYDS

在这里插入图片描述

然后再写入excel 表 yyds

#!/bin/env python3
from git.repo import Repo
import os
import pandas as pdspath = "/home/labstation/workqueue/sw"
url = "git@10.0.128.128"
date = [str(x) for x in range(202307, 202308)]
datefmt = "%Y%m"
counts = 0
AUTHORS = {}
AUTHORS_UNIQU = {}
DATE = {}
DATE_UNIQU = {}for proj in os.scandir(path):if not os.access(path + "/" + proj.name + "/.git", os.F_OK):continuerepo = Repo(path + "/" + proj.name)remoteUrl = repo.git.execute(["git", "remote", "-v"])if type(remoteUrl) is str:remoteUrl = map(lambda x: x.strip("\t"), remoteUrl.split("\n"))for checkUrl in remoteUrl:if checkUrl.find(url) > 0:continueres = repo.git.execute(["git", "branch", "-r"])if type(res) is str and len(res) != 0:branches = filter(lambda x: not x.startswith("origin/HEAD"),map(lambda x: x.strip(" "), res.split("\n")),)for it_branch in branches:for it in repo.iter_commits(it_branch):if it.authored_datetime.strftime(datefmt) in date:AUTHORS[str(it)] = it.author.nameDATE[str(it)] = (it_branch,proj.name,it.author.name,it.authored_datetime.strftime(datefmt),)for _it in AUTHORS:AUTHORS_UNIQU[AUTHORS[_it]] = 0for _it in AUTHORS_UNIQU:for _its in AUTHORS:if _it == AUTHORS[_its]:AUTHORS_UNIQU[_it] += 1for _it in DATE:DATE_UNIQU[DATE[_it]] = 0for _it in DATE_UNIQU:for _its in DATE:if _it == DATE[_its]:DATE_UNIQU[_it] += 1TotalExcel = {"姓名": [], "次数": []}for _it in AUTHORS_UNIQU:TotalExcel["姓名"].append(_it)TotalExcel["次数"].append(AUTHORS_UNIQU[_it])Excel = {"分支": [], "仓库名称": [], "提交者": [], "提交日期": [], "提交次数": []}
for it in DATE_UNIQU:Excel["分支"].append(it[0])Excel["仓库名称"].append(it[1])Excel["提交者"].append(it[2])Excel["提交日期"].append(it[3])Excel["提交次数"].append(DATE_UNIQU[it])writer = pds.ExcelWriter(date[0] + "~" + date[len(date) - 1] + ".xlsx")
excekWrute2 = pds.DataFrame(TotalExcel)
excekWrute2.to_excel(writer, sheet_name="统计总表")
execlWrite1 = pds.DataFrame(Excel)
execlWrite1.to_excel(writer, sheet_name="各仓库统计")
writer.close()

保存成excel 表格输出

YYDS … …


http://www.ppmy.cn/news/997763.html

相关文章

【PyQt实现复现框CheckBox】

PyQt实现复现框CheckBox 1 安装环境2 CtrlN,新建Main Window窗口,保存为checkBox.ui文件3 CheckBox的三种状态4 实现通用复选框的选中状态设置用户权限功能 1 安装环境 1)Python环境安装PyQt5、PyQt-sip、PyQt5Designer、PyQt5-tools 2&…

【Deepsort】C++版本Deepsort编译(依赖opencv,eigen3)

目录 下载源码安装onnxruntime安装Eigen3编译opencv 下载源码 https://github.com/shaoshengsong/DeepSORT安装onnxruntime 安装方法参考博客 安装Eigen3 当谈及线性代数计算库时,Eigen3是一个强大而受欢迎的选择。Eigen3是一个C模板库,提供了许多用…

ChatGPT的功能与特点

随着人工智能技术的不断发展,ChatGPT作为OpenAI公司开发的基于GPT-3.5架构的大型语言模型,正引领着智能交互的新纪元。ChatGPT的功能与特点使其能够在多个领域展现出惊人的能力,本文将深入探讨ChatGPT的功能与特点,以及它在人工智…

Linux常用命令——dpkg-divert命令

在线Linux命令查询工具 dpkg-divert Debian Linux中创建并管理一个转向列表 补充说明 dpkg-divert命令是Debian Linux中创建并管理一个转向(diversion)列表,其使得安装文件的默认位置失效的工具。 语法 dpkg-divert(选项)(参数)选项 -…

手撕SpringBoot的自定义启动器

一. 前言 哈喽,大家好,最近金九银十,又有不少小伙伴私信辉哥,说自己在面试时被问到SpringBoot如何自定义启动器,结果自己不知道该怎么回答。那么今天就手把手地带着大家,去看看在SpringBoot中到底该怎么实…

Kafka3.0.0版本——Broker(Zookeeper服务端存储的Kafka相关信息)

目录 一、启动zookeeper集群及kafka集群服务启动1.1、先启动三台zookeeper集群服务,再启动三台kafka集群服务1.2、使用PrettyZoo连接zookeeper客户端工具 二、在zookeeper服务端存储的Kafka相关信息 一、启动zookeeper集群及kafka集群服务启动 1.1、先启动三台zook…

Matlab进阶绘图第24期—悬浮柱状图

悬浮柱状图是一种特殊的柱状图。 与常规柱状图相比,悬浮柱状图可以通过悬浮的矩形展示最小值到最大值的范围(或其他范围表达),因此在多个领域得到应用。 本文使用自己制作的Floatingbar小工具进行悬浮柱状图的绘制,先…

Jmeter —— jmeter参数化实现

jmeter参数化 在实际的测试工作中,我们经常需要对多组不同的输入数据,进行同样的测试操作步骤,以验证我们的软件的功能。这种测试方式在业界称为数据驱动测试, 而在实际测试工作中,测试工具中实现不同数据输入的过程称…