• 代码发布系列1


    1.Python操作git

    """
    基于Python实现对git仓库进行操作,使用前需要安装模块:gitpython
        pip3 install gitpython
    """
     
    # ############## 1. clone下载代码 ##############
    """
    import os
    from git.repo import Repo
     
    download_path = os.path.join('code', 'fuck')
    Repo.clone_from('https://gitee.com/wupeiqi/fuck.git', to_path=download_path, branch='master')
    """
     
    # ############## 2. pull最新代码 ##############
    """
    import os
    from git.repo import Repo
     
    local_path = os.path.join('code', 'fuck')
    repo = Repo(local_path)
    repo.git.pull()
    """
    # ############## 3. 获取所有分支 ##############
    """
    import os
    from git.repo import Repo
     
    local_path = os.path.join('code', 'fuck')
    repo = Repo(local_path)
     
    branches = repo.remote().refs
    for item in branches:
        print(item.remote_head)
    """
    # ############## 4. 获取所有版本 ##############
    """
    import os
    from git.repo import Repo
     
    local_path = os.path.join('code', 'fuck')
    repo = Repo(local_path)
     
    for tag in repo.tags:
        print(tag.name)
    """
     
    # ############## 5. 获取所有commit ##############
    """
    import os
    from git.repo import Repo
     
    local_path = os.path.join('code', 'fuck')
    repo = Repo(local_path)
     
    commit_log = repo.git.log('--pretty={"commit":"%h","author":"%an","summary":"%s","date":"%cd"}', max_count=50,
                              date='format:%Y-%m-%d %H:%M')
    log_list = commit_log.split("
    ")
    real_log_list = [eval(item) for item in log_list]
    print(real_log_list)
    """
     
    # ############## 6. 切换分支 ##############
    """
    import os
    from git.repo import Repo
     
    local_path = os.path.join('code', 'fuck')
    repo = Repo(local_path)
     
    before = repo.git.branch()
    print(before)
    repo.git.checkout('master')
    after = repo.git.branch()
    print(after)
    repo.git.reset('--hard', '854ead2e82dc73b634cbd5afcf1414f5b30e94a8')
    """
     
    # ############## 7. 打包代码 ##############
    """
    with open(os.path.join('code', 'fuck.tar'), 'wb') as fp:
        repo.archive(fp)
    """
    

    1.2把git操作封装成一个类

    import os
    from git.repo import Repo
    from git.repo.fun import is_git_dir
    
    
    class GitRepository(object):
        """
        git仓库管理
        """
    
        def __init__(self, local_path, repo_url, branch='master'):
            self.local_path = local_path
            self.repo_url = repo_url
            self.repo = None
            self.initial(repo_url, branch)
    
        def initial(self, repo_url, branch):
            """
            初始化git仓库
            :param repo_url:
            :param branch:
            :return:
            """
            if not os.path.exists(self.local_path):
                os.makedirs(self.local_path)
    
            git_local_path = os.path.join(self.local_path, '.git')
            if not is_git_dir(git_local_path):
                self.repo = Repo.clone_from(repo_url, to_path=self.local_path, branch=branch)
            else:
                self.repo = Repo(self.local_path)
    
        def pull(self):
            """
            从线上拉最新代码
            :return:
            """
            self.repo.git.pull()
    
        def branches(self):
            """
            获取所有分支
            :return:
            """
            branches = self.repo.remote().refs
            return [item.remote_head for item in branches if item.remote_head not in ['HEAD', ]]
    
        def commits(self):
            """
            获取所有提交记录
            :return:
            """
            commit_log = self.repo.git.log('--pretty={"commit":"%h","author":"%an","summary":"%s","date":"%cd"}',
                                           max_count=50,
                                           date='format:%Y-%m-%d %H:%M')
            log_list = commit_log.split("
    ")
            return [eval(item) for item in log_list]
    
        def tags(self):
            """
            获取所有tag
            :return:
            """
            return [tag.name for tag in self.repo.tags]
    
        def change_to_branch(self, branch):
            """
            切换分值
            :param branch:
            :return:
            """
            self.repo.git.checkout(branch)
    
        def change_to_commit(self, branch, commit):
            """
            切换commit
            :param branch:
            :param commit:
            :return:
            """
            self.change_to_branch(branch=branch)
            self.repo.git.reset('--hard', commit)
    
        def change_to_tag(self, tag):
            """
            切换tag
            :param tag:
            :return:
            """
            self.repo.git.checkout(tag)
    
    
    if __name__ == '__main__':
        local_path = os.path.join('codes', 'luffycity')
        repo = GitRepository(local_path, 'https://gitee.com/wupeiqi/fuck.git')
        branch_list = repo.branches()
        print(branch_list)
        repo.change_to_branch('dev')
        repo.pull()
    

    2.python压缩文件相关

    在py2和py3中对文件进行解压缩稍有不同。

    • shutil 模块【压缩支持py2和py3,解压只支持py3】
    • tarfile / zipfile模块【支持py2和py3】

    shutil模块示例

    import shutil
    
    # 文件压缩
    """
    ret = shutil.make_archive(
        base_name="code/www",  # 压缩包文件路劲
        format='zip',  # “zip”, “tar”
        root_dir='code/fuck'  # 被压缩的文件件
    )
    print(ret)
    """
    
    # 解压文件
    """
    shutil._unpack_zipfile('code/www.zip', 'code/new')
    shutil._unpack_tarfile('code/www.tar', 'code/new')
    """
    
    shutil模块
    

    zipfile模块示例

    import zipfile
    
    # 压缩
    z = zipfile.ZipFile('laxi.zip', 'w')
    z.write('a.log')
    z.write('data.data')
    z.close()
    
    # 解压
    z = zipfile.ZipFile('laxi.zip', 'r')
    z.extractall()
    z.close()
    
    zipfile模块
    

    tarfile模块示例

    import tarfile
    
    # 压缩
    tar = tarfile.open('your.tar', 'w')
    tar.add('utils/codes/luffycity/a1.py')
    tar.add('utils/codes/luffycity/a3.py')
    tar.close()
    
    # 解压
    tar = tarfile.TarFile('code/www.tar', 'r')
    tar.extractall(path='/code/x1/')  # 可设置解压地址
    tar.close()
    
    tarfile模块
    

    3.执行本地命令

    import subprocess
     
    result = subprocess.check_output('ls -l', cwd='/Users/wupeiqi/PycharmProjects', shell=True)
    print(result.decode('utf-8'), type(result))
    

    4.Paramiko执行远程操作

    import paramiko
    
    
    class SSHProxy(object):
    
        def __init__(self, hostname, port, username, private_key_path):
            self.hostname = hostname
            self.port = port
            self.username = username
            self.private_key_path = private_key_path
    
            self.transport = None
    
        def open(self):
            private_key = paramiko.RSAKey.from_private_key_file(self.private_key_path)
            self.transport = paramiko.Transport((self.hostname, self.port))
            self.transport.connect(username=self.username, pkey=private_key)
    
        def close(self):
            self.transport.close()
    
        def command(self, cmd):
            ssh = paramiko.SSHClient()
            ssh._transport = self.transport
            stdin, stdout, stderr = ssh.exec_command(cmd)
            result = stdout.read()
            ssh.close()
            return result
    
        def upload(self, local_path, remote_path):
            sftp = paramiko.SFTPClient.from_transport(self.transport)
            sftp.put(local_path, remote_path)
            sftp.close()
    
        def __enter__(self):
            self.open()
            return self
    
        def __exit__(self, exc_type, exc_val, exc_tb):
            self.close()
    
    
    if __name__ == '__main__':
        with SSHProxy('10.211.55.25', 22, 'root', '/Users/wupeiqi/.ssh/id_rsa') as proxy:
            proxy.upload('xx','xx')
            proxy.command('ifconfig')
            proxy.command('ifconfig')
            proxy.upload('xx', 'xx')
        with SSHProxy('10.211.55.26', 22, 'root', '/Users/wupeiqi/.ssh/id_rsa') as proxy:
            proxy.upload('xx','xx')
            proxy.command('ifconfig')
            proxy.command('ifconfig')
            proxy.upload('xx', 'xx')
    
  • 相关阅读:
    安装HyperV后VirtualBox打开故障
    TortoiseGit或TortoiseSVN在软件或系统更新后图标丢失的一个解决办法
    WSL2 Ubuntu1604 安装 GUI图形库 和 Qt Creator
    时序约束(小梅哥)
    FPGA加速
    吴恩达机器学习笔记
    Neural Network and Deep Learning 笔记【第二章;反向传播算法如何⼯作】
    Tcl学习记录
    Neural Network and Deep Learning 笔记【第一章;手写数字识别】
    操作符重载
  • 原文地址:https://www.cnblogs.com/Tao9/p/11944275.html
Copyright © 2020-2023  润新知