代码版本管理笔记 | Python 程序员也应该会的 Git 基础操作

简介: 代码版本管理笔记 | Python 程序员也应该会的 Git 基础操作

设置配置信息

# 初始配置
git config --global user.name "你的昵称"
git config --global user.email "你的邮箱"
# 如果写错了
# 命令行修改如下
git config --global --replace-all user.name "your user name"
git config --global --replace-all user.email"your user email"
# 修改文件的方式,主要是修改位于主目录下 .gitconfig 文件。在 Linux  和 Mac  中,可以通过 vim  命令进行直接编辑,比如 vim ~/.gitconfig
#  Windows  系统同样位于用户主目录下,假设你当前的用户是 administrator ,那么对应的配置文件的路径应该是 C:\Users\administrator\.gitconfig
# 下面的位置
[user]
name = your user name
email = your user email

常用操作

# 检查改动文件
git status
# 回滚文件
git checkout [filename]
# 添加文件到暂存区
git add [filename]
# 提交代码
git commit . -m "备注"
# 推送代码
git push

git 版本比较

比较工作区的变动

git diff [path/filename] [path/filename]

比较暂存区和版本库的变动

git diff --cached [filename]

与指定版本做比较

# 1
git log # 找到要对比的版本的 hash 值
# 2 工作区文件与指定版本比较
git diff hash值
# 3 暂存区与指定版本比较
git diff --cached hash值

与最新版本做比较

将未正式提交的代码(包含工作区与暂存区)与最新的 commit  记录进行比较,虽然也可以通过指定 commit  的 hash  值进行,但是却很不方便,需要先获取到 hash  值,这里推荐使用与 HEAD 比较的方式

git diff HEAD

对比两个历史记录

首先通过 git log 命令获取到需要查看的记录 hash  值,然后再找到这个记录的上一个版本的 hash  值

git diff hash值1 hash值2

git 权限控制

# 处理版本权限冲突的方法
# 当前版本库
git config core.filemode false
# 全局版本库
git config --global core.filemode false

忽略指定文件或目录

# 在根目录下创建 .gitignore 文件
vm .gitignore
# 将要忽略的文件写入

检查某一个文件提交不上的问题

git check-ignore -v [filename]

强制添加某一个文件至忽略的清单

git add -f [filename]

设置忽略排除

假如我们需要将某一个文件下的大部分文件都忽略,只提交某一个或多个文件

# 需要先设置 ignore 整个文件夹
1、vim .gitignore
# 设置将 test 整个文件夹忽略
2、输入 test/*
# 设置取消忽略 test 文件夹下的 index.html 文件
3、输入 !test/index.html

忽略已经提交的文件

一不小心把某一个原本应该忽略的目录提交到了版本控制器中,再使用 .gitignore 文件去忽略的时候,发现无论如何都无法再次将其忽略

忽略已存在的文件

我们需要先删除掉该文件的缓存,才能让他成功忽略,所以正确的操作步骤是先在 .gitignore  中设置该文件为忽略,然后执行删除缓存命令

git rm --cached xxx/xxx

忽略已存在的文件夹

忽略已存在的文件夹方式和上面基本一致, 编辑 .gitignore 文件,在文件中加入要忽略文件夹然后使用删除该文件夹的缓存

git rm -r --cached xxx/

reset 恢复

这个命令可以撤销我们最近一次提交

git reset HEAD^

指定 commit id 恢复到指定记录

git log
git reset [commit id]

咸鱼学Python

专注分享网络爬虫,Python,JS逆向,爬虫进阶,APP逆向,移动安全等相关知识

287篇原创内容

公众号


相关文章
|
2天前
|
缓存 监控 测试技术
Python中的装饰器:功能扩展与代码复用的利器###
本文深入探讨了Python中装饰器的概念、实现机制及其在实际开发中的应用价值。通过生动的实例和详尽的解释,文章展示了装饰器如何增强函数功能、提升代码可读性和维护性,并鼓励读者在项目中灵活运用这一强大的语言特性。 ###
|
5天前
|
缓存 开发者 Python
探索Python中的装饰器:简化代码,增强功能
【10月更文挑战第35天】装饰器在Python中是一种强大的工具,它允许开发者在不修改原有函数代码的情况下增加额外的功能。本文旨在通过简明的语言和实际的编码示例,带领读者理解装饰器的概念、用法及其在实际编程场景中的应用,从而提升代码的可读性和复用性。
|
1天前
|
Python
探索Python中的装饰器:简化代码,提升效率
【10月更文挑战第39天】在编程的世界中,我们总是在寻找使代码更简洁、更高效的方法。Python的装饰器提供了一种强大的工具,能够让我们做到这一点。本文将深入探讨装饰器的基本概念,展示如何通过它们来增强函数的功能,同时保持代码的整洁性。我们将从基础开始,逐步深入到装饰器的高级用法,让你了解如何利用这一特性来优化你的Python代码。准备好让你的代码变得更加优雅和强大了吗?让我们开始吧!
7 1
|
6天前
|
设计模式 缓存 监控
Python中的装饰器:代码的魔法增强剂
在Python编程中,装饰器是一种强大而灵活的工具,它允许程序员在不修改函数或方法源代码的情况下增加额外的功能。本文将探讨装饰器的定义、工作原理以及如何通过自定义和标准库中的装饰器来优化代码结构和提高开发效率。通过实例演示,我们将深入了解装饰器的应用,包括日志记录、性能测量、事务处理等常见场景。此外,我们还将讨论装饰器的高级用法,如带参数的装饰器和类装饰器,为读者提供全面的装饰器使用指南。
|
2天前
|
存储 缓存 监控
掌握Python装饰器:提升代码复用性与可读性的利器
在本文中,我们将深入探讨Python装饰器的概念、工作原理以及如何有效地应用它们来增强代码的可读性和复用性。不同于传统的函数调用,装饰器提供了一种优雅的方式来修改或扩展函数的行为,而无需直接修改原始函数代码。通过实际示例和应用场景分析,本文旨在帮助读者理解装饰器的实用性,并鼓励在日常编程实践中灵活运用这一强大特性。
|
4天前
|
机器学习/深度学习 数据采集 人工智能
探索机器学习:从理论到Python代码实践
【10月更文挑战第36天】本文将深入浅出地介绍机器学习的基本概念、主要算法及其在Python中的实现。我们将通过实际案例,展示如何使用scikit-learn库进行数据预处理、模型选择和参数调优。无论你是初学者还是有一定基础的开发者,都能从中获得启发和实践指导。
11 2
|
6天前
|
数据库 Python
异步编程不再难!Python asyncio库实战,让你的代码流畅如丝!
在编程中,随着应用复杂度的提升,对并发和异步处理的需求日益增长。Python的asyncio库通过async和await关键字,简化了异步编程,使其变得流畅高效。本文将通过实战示例,介绍异步编程的基本概念、如何使用asyncio编写异步代码以及处理多个异步任务的方法,帮助你掌握异步编程技巧,提高代码性能。
20 4
|
Linux 网络安全 数据处理
Git 使用笔记
Git 使用笔记
108 0
|
Shell 网络安全 开发工具
|
开发工具 git
Git使用笔记
1. 常用命令 下载一个项目和它的整个代码历史 git clone [**.git] 比较当前文件和暂存区文件差异 git diff 将工作文件修改提交到本地暂存区 git add -A git add 显示有变更的文件 git status 提交暂...
944 0