代码拉取完成,页面将自动刷新
同步操作将从 java/git-stats 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
# encoding: utf8
import os
import json
import datetime
import requests
import smtplib
import csv
import sys, getopt
from email import encoders
from email.header import Header
from email.mime.text import MIMEText
from email.utils import parseaddr, formataddr
from email_name_dict import email_name
project_result = {}
#防重处理
all_commits={}
# 参数
params = {
"token": '', # token信息
"base_url": 'https://git.opsnow.tech/api/v4', #gitlab api访问url前缀, eg. https://gitlab.com/api/v4
"since_date": '', #统计开始日期, eg. 2019-09-05 00:00:00
"until_date": '' # 统计终止日期, eg. 2019-09-12 00:00:00
}
def get_data(url):
headers = {
"PRIVATE-TOKEN": params['token']
}
rs = []
try:
r = requests.get(url, headers=headers)
except Exception as e:
print(e)
else:
rs = r.json()
return rs
#http://git.opsnow.tech/api/v4/groups/47/issues\?state\=opened
# /projects/:id/issues
def get_issue_by_projectid(project_id):
url = "%s/projects/%s/issues?per_page=2000" % (params['base_url'], project_id)
return get_data(url)
# /projects/:id/repository/commits?ref_name=master&since=&until=
def get_commits(project_id, project_name, branch_name, group_name):
result = []
page = 1
commits = get_commits_page(project_id, project_name, branch_name, group_name, page)
while len(commits) > 0:
result.extend(commits)
page = page + 1
commits = get_commits_page(project_id, project_name, branch_name, group_name, page)
return result
def get_commits_page(project_id, project_name, branch_name, group_name, page):
url = "%s/projects/%s/repository/commits?page=%s&per_page=100&ref_name=%s&since=%s&until=%s&with_stats=yes" % (params['base_url'], project_id, page, branch_name, params['since_date'], params['until_date'])
rs = get_data(url)
commit_details = []
for commit in rs:
commit_id = commit['id']
if commit_id in all_commits:
continue
all_commits[commit_id] = commit
stats = commit['stats']
author_name = commit['author_name']
commiter_email = commit['committer_email']
if commiter_email in email_name:
author_name = email_name[commiter_email]
commit_details.append({
'commit_id': commit_id,
'name': commit['committer_name'],
'email': commit['committer_email'],
'author_name': author_name,
'group': group_name,
'project':project_name,
'branch': branch_name,
'additions': stats['additions'],
'deletions': stats['deletions'],
'total': stats['total'],
'commit_count': 1
})
return commit_details
# /projects/:id/repository/branches/
def get_branches(project_id):
page = 1
result = []
branches = get_branches_page(project_id, page)
while len(branches) > 0:
result.extend(branches)
page = page + 1
branches = get_branches_page(project_id, page)
return result
def get_branches_page(project_id, page):
url = "%s/projects/%s/repository/branches?page=%s&per_page=100" % (params['base_url'], project_id, page)
rs = get_data(url)
result = []
for branch in rs:
branch_name = branch['name']
result.append(branch_name)
return result
# /projects
def get_projects():
url = "%s/projects?per_page=2000" % params['base_url']
rs = get_data(url)
projects = []
namespaces = {}
count = 0
for project in rs:
p = {
"id": project['id'],
"name": project['name'],
"path_with_namespace": project['path_with_namespace'],
"ssh_url_to_repo": project['ssh_url_to_repo'],
"http_url_to_repo": project['http_url_to_repo'],
"namespace": project['namespace']['full_path'],
"branches": []
}
# if p['namespace'].startswith('PD/Private2.0') or p['namespace'].startswith('oc-si') or p['namespace'].startswith('PD/Private'):
# projects.append(p)
projects.append(p)
namespaces[p['namespace']] = {}
return projects
def write_csv_obj(filename, headers, data_rows):
with open(filename, 'w', encoding='utf-8-sig') as f:
f_csv = csv.DictWriter(f, headers)
f_csv.writeheader()
f_csv.writerows(data_rows)
def write_csv_dict(filename, headers, data_dict):
with open(filename, 'w', encoding='utf-8-sig') as f:
f_csv = csv.DictWriter(f, headers)
f_csv.writeheader()
for k, v in data_dict.items():
f_csv.writerow(v)
def stas():
print('sdfsdfsdfsdfsdf')
projects = get_projects()
project_headers = ["id",
"name",
"path_with_namespace",
"ssh_url_to_repo",
"http_url_to_repo",
"namespace",
"branches"]
write_csv_obj('./projects.csv', project_headers, projects)
print('1. 获取项目结束, 共有项目数量:', len(projects))
commits = []
for p in projects:
project_id = p['id']
project_name = p['name']
branches = get_branches(project_id)
p['branches'] = branches
print('2. 获取项目', project_name, '分支结束', '分支数量:', len(branches))
for b in branches:
branch_commits = get_commits(project_id, project_name, b, p['namespace'])
print('3. 获取项目', p['namespace'], '/', project_name, ' 分支:', b, '所有提交结束, len:', len(branch_commits))
commits += branch_commits
print('total commits len:', len(commits))
print('commits len:', len(commits))
commit_details_headers = ['commit_id','name', 'email', 'author_name','group','project', 'branch', 'additions', 'deletions', 'total','commit_count']
# 保存提交日志明细到commit_details.csv文件
write_csv_obj('./commit_details.csv', commit_details_headers, commits)
author_stats = {}
print('4. 获取所有提交结束,开始进行统计')
for commit in commits:
author_name = commit['email']
if author_name in author_stats:
author_commit = author_stats[author_name]
author_commit['additions'] += commit['additions']
author_commit['deletions'] += commit['deletions']
author_commit['total'] += commit['total']
author_commit['commit_count'] += 1
else:
author_stats[author_name] = {
'name': commit['name'],
'email': commit['email'],
'author_name': commit['author_name'],
'group': commit['group'],
'project':commit['project'],
'additions': commit['additions'],
'deletions': commit['deletions'],
'total': commit['total'],
'commit_count': commit['commit_count']
}
# print(author_stats)
commit_stats_headers = ["group", "project", "email", "name", 'author_name', "additions", "deletions", "total", "commit_count"]
write_csv_dict('./commit_stats.csv', commit_stats_headers, author_stats)
# write_csv_file(author_stats)
def usage():
msg = "Usage: %s -t <token> -s <since_date> -u <until_date> -a <api_url> [-h] or %s --token <token> --sincedate <since_date> --untildate <until_date> --apiurl <api_url> [--help]" % (sys.argv[0], sys.argv[0])
print(msg)
# 处理参数
def main(argv):
try:
opts, args = getopt.getopt(argv, "ht:s:u:a:", ["help", "token=", "sincedate=", "untildate=", "apiurl="])
except getopt.GetoptError:
usage()
sys.exit(2)
has_token = 0 # 是否传了token参数
has_since_date = 0 # 开始时间
has_until_date = 0 # 结束时间
for opt, arg in opts:
if opt in ('h', 'help'):
usage()
sys.exit()
elif opt in ("-t", "--token"):
params['token'] = arg
has_token = 1
elif opt in ("-s", "--sincedate"):
params['since_date'] = arg
has_since_date = 1
elif opt in ("a", "--apiurl"):
params['base_url'] = arg
elif opt in ("-u", "--untildate"):
params['until_date'] = arg
has_until_date = 1
if has_token == 0 or has_since_date == 0 or has_until_date == 0:
usage()
sys.exit()
print(params)
stas()
if __name__ == "__main__":
main(sys.argv[1:])
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。