首页 > 其他分享 >全自动批量 Fork Star 仓库

全自动批量 Fork Star 仓库

时间:2023-04-02 17:25:31浏览次数:33  
标签:Fork fork Star name repository url response api 全自动

import requests
import json
import time

forker_name = "USERNAME1"  # fork到这个用户里
forker_pwd = "PASSWORD"  # personal access token
forkee_name = "USERNAME2"  # 需要被fork的用户
interval = 17  # 每个仓库fork的时间间隔,单位:秒
write2file = True  # 是否将被fork的用户所有仓库地址写到文件里

####################################################################
####################################################################
####################################################################

api_url_get = f"https://api.github.com/users/{forkee_name}/repos"
repositories = []
repository_urls = []
page_number = 1
while True:
    # 发送API请求并检查响应状态码
    response_get = requests.get(api_url_get, params={"per_page": 100, "page": page_number})
    if response_get.status_code != 200:
        print(f"Failed to get repositories for user {forkee_name}. Status code: {response_get.status_code}")
        break

    # 解析JSON响应并将仓库信息添加到repositories列表中
    repository_data = json.loads(response_get.content)
    if len(repository_data) == 0:
        break
    repositories += repository_data
    page_number += 1

if write2file:
    # 将仓库信息写入文件
    file_name = f"{forkee_name}_Github_Repos.txt"
    with open(file_name, "w") as file:
        # 遍历所有获取到的仓库
        for repository in repositories:
            file.write(f"{repository['html_url']}\n")
            repository_urls.append(repository['html_url'])
    print(f"All repositories of {forkee_name} are saved in file '{file_name}'.")

# 使用GitHub API将每个仓库fork到你的GitHub账户中,并同时star
for url in repository_urls:
    ### print(url)
    # 从URL中解析出owner和repo名称
    splitted_str_arr = url.split("/")
    owner = splitted_str_arr[len(splitted_str_arr) - 2]
    repo = splitted_str_arr[len(splitted_str_arr) - 1]
    print(f"Start forking {repo}...")

    ##################################################################
    # 发送API请求以fork仓库
    api_url_fork = f"https://api.github.com/repos/{owner}/{repo}/forks"
    response_fork = requests.post(api_url_fork, auth=(forker_name, forker_pwd))

    # 检查响应状态码和JSON响应中的信息
    if response_fork.status_code == 202:
        print(f"Successfully forked {url}.")
    else:
        error_message = json.loads(response_fork.content)["message"]
        print(f"Failed to fork {url}. Error message: {error_message}")
    time.sleep(interval)

    ##################################################################
    # 发送API请求以star仓库
    api_url_star = f"https://api.github.com/user/starred/{owner}/{repo}"
    response_star = requests.put(api_url_star, auth=(forker_name, forker_pwd))

    # 检查响应状态码和JSON响应中的信息
    if response_star.status_code == 204:
        print(f"Successfully starred {url}.")
    else:
        error_message = json.loads(response_star.content)["message"]
        print(f"Failed to star {url}. Error message: {error_message}")
    time.sleep(interval + 1)




作者:艾孜尔江

标签:Fork,fork,Star,name,repository,url,response,api,全自动
From: https://www.cnblogs.com/ezhar/p/17280810.html

相关文章

  • 半自动批量Fork Star仓库
    importrequestsimportjsonimporttimeforker_name="USERNAME1"#fork到这个用户里forker_pwd="PASSWORD"#personalaccesstokeninterval=10#每个仓库fork的时间间隔,单位:秒urls_file='URLs.txt'#存放用户仓库地址列表的外部文件名################......
  • 批量Star仓库
    importrequestsimportjsonimporttimename="USERNAME"#Githubusernamepwd="PASSWORD"#personalaccesstoken#要star的仓库地址列表repository_urls=["https://github.com/Ezharjan/X-PostProcessing-Library","h......
  • 批量Fork仓库
    importrequestsimportjsonimporttimename="USERNAME"#Githubusernamepwd="PASSWORD"#personalaccesstoken#要fork的仓库地址列表repository_urls=["https://github.com/Ezharjan/X-PostProcessing-Library","h......
  • springboot-自己开发start
    步骤命名规范第三方在建立自己的Starter的时候命名规则统一用xxx-spring-boot-starter,官方提供的Starter统一命名方式为spring-boot-starter-xxx。步骤新建一个Maven项目,在pom.xml文件中定义好所需依赖;新建配置类,写好配置项和默认值,使用@ConfigurationProperties指明......
  • PXE+Kickstart无人值守安装
    1、概述PXE(prebootexecuteenvironment,预启动执行环境)是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支持工作站通过网络从远端服务器下载映像,并由此支持通过网络启动操作系统,在启动过程中,终端要求服务器分配IP地址,再用TFTP(trivialfiletransferprotocol)或MTFTP......
  • Project 'org.springframework.boot:spring-boot-starter-parent:XXX' not found
    问题:Project'org.springframework.boot:spring-boot-starter-parent:XXX'notfound当spring-boot-starter-parent下面的版本报红时并不是这个版本不存在,而是因为idea会默认缓存Maven本地仓库已存在的中的依赖项。只是我们引入的的父依赖版本在本地仓库中不存在,所以就报......
  • omron欧姆龙NJ NX程序 全自动锂电池二封机,主站NJ501-1400+威纶通触摸屏
    omron欧姆龙NJNX程序全自动锂电池二封机,主站NJ501-1400+威纶通触摸屏。整机采用EtherCAT总线网络节点控制,松下A6总线控制。轴控制全部封装成功能块,可按照使用选择对应......
  • MySQL安装 starting the server解决办法
    https://blog.csdn.net/qq_52183856/article/details/123792012主要原因:......
  • 什么是kickstart?
    原文地址:https://blog.csdn.net/My_name_is_ZwZ/article/details/83961958目录 什么是kickstart批量安装什么是Cobbler?Kickstart中的各模块Kickstart如何配置kick......
  • 在Linux系统下创建子进程-fork()函数
    Linux系统下创建子进程在Linux终端下输入命令:man2fork,查看fork()函数的描述:/*NAMEfork-createachildprocess#include<sys/types.h>#include......