git常用命令笔记

在Windows上安装Git

在Windows上使用Git,可以从Git官网直接下载安装程序国内镜像), 按默认选项安装即可。

安装完成后,在安装根目录打开git-bash.exe

 

在命令行输入:

$ git config --global user.name "your name"
$ git config --global user.email "email@example.com"

因为Git是分布式版本控制系统,所以每个机器都需要设置你的名字和Email地址作为来源标记

初始化一个Git仓库,使用git init命令

添加文件到Git仓库,分两步:

  1. 使用命令git add <file>,注意,可反复多次使用,添加多个文件;
  2. 使用命令git commit -m <message>,完成。
$ git add file1.txt
$ git add file2.txt file3.txt
$ git commit -m "add 3 files."
  1. 要随时掌握工作区的状态,使用git status命令。
  2. 如果git status告诉你有文件被修改过,用git diff可以查看修改内容。
  3. git log命令显示从最近到最远的提交日志,如果嫌输出信息太多,看得眼花缭乱的,可以试试加上--pretty=oneline参数
git log --pretty=oneline
  1. 在Git中,用HEAD表示当前版本,上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100
  2. 我们要把当前版本回退到上一个版本就可以使用git reset命令
  3. 要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本。
$ git reset --hard HEAD^
$ git reset --hard commit_id
  1. git checkout -- file可以丢弃工作区的修改,让这个文件回到最近一次git commitgit add时的状态,git checkout -- file命令中的--很重要,没有--,就变成了“切换到另一个分支”的命令
  2. git reset HEAD <file>git reset命令既可以回退版本,也可以把暂存区的修改回退到工作区。当我们用HEAD时,表示最新的版本。
  3. git rm <file>,命令git rm用于删除一个文件。先手动删除文件,然后使用git rm <file>和git add<file>效果是一样的。

GitHub的使用

  1. 先有本地库,后有远程库的时候,要关联一个远程库,使用命令git remote add origin git@server-name:path/repo-name.git
  2. 更改仓库指向git remote set-url origin git@server-name:path/repo-name.git
  3. 关联后,使用命令git push -u origin master第一次推送master分支的所有内容;
  4. 此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改;
  5. 假设我们从零开发,那么最好的方式是先创建远程库,然后,从远程库克隆,用命令git clone克隆一个本地库
  6. 创建SSH Key。在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有id_rsaid_rsa.pub这两个文件,如果已经有了,可直接跳到下一步。如果没有,打开Shell(Windows下打开Git Bash),创建SSH Key:
$ ssh-keygen -t rsa -C "youremail@example.com"

分支

  1. 查看分支:git branch
  2. 创建分支:git branch <name>
  3. 切换分支:git checkout <name>
  4. 创建+切换分支:git checkout -b <name>可以通过git branch -D <name>强行删除 
  5. 合并某分支到当前分支:git merge <name>, 合并分支时,加上--no-ff参数就可以用普通模式合并,合并后的历史有分支
  6. 删除分支:git branch -d <name>
  7. 看到分支合并图:git log --graph
$ git checkout -b dev
$ git branch
* dev
  master
$ git checkout master
$ git merge dev
$ git merge --no-ff -m "merge with no-ff" dev
$ git branch -d dev
$ git log --graph --pretty=oneline --abbrev-commit

stash功能,可以把当前工作现场“储藏”起来

  1. Git还提供了一个stash功能,可以把当前工作现场“储藏”起来,等以后恢复现场后继续工作git stash
  2. 刚才的工作现场存到哪去了?用git stash list命令看看
  3. 恢复工作现场有两个办法:一是用git stash apply恢复,但是恢复后,stash内容并不删除,你需要用git stash drop来删除;另一种方式是用git stash pop,恢复的同时把stash内容也删了
  4. $ git stash
    $ git stash list
    $ git stash apply
    $ git stash drop
    $ git stash pop

多人协作

  1. 当你从远程仓库克隆时,实际上Git自动把本地的master分支和远程的master分支对应起来了,并且,远程仓库的默认名称是origin,要查看远程库的信息,用git remote,git remote -v显示更详细的信息
  2. 本地新建的分支如果不推送到远程,对其他人就是不可见的;
  3. 从本地推送分支,使用git push origin branch-name,如果推送失败,先用git pull抓取远程的新提交;
  4. 在本地创建和远程分支对应的分支,使用git checkout -b branch-name origin/branch-name,本地和远程分支的名称最好一致;
  5. 建立本地分支和远程分支的关联,使用git branch --set-upstream branch-name origin/branch-name
  6. 从远程抓取分支,使用git pull,如果有冲突,要先处理冲突。
$ git remote
origin
$ git remote -v

因此,多人协作的工作模式通常是这样

  1. 首先,可以试图用git push origin <branch-name>推送自己的修改;
  2. 如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并;
  3. 如果合并有冲突,则解决冲突,并在本地提交;
  4. 没有冲突或者解决掉冲突后,再用git push origin <branch-name>推送就能成功!

如果git pull提示no tracking information,则说明本地分支和远程分支的链接关系没有创建,

用命令git branch --set-upstream-to <branch-name> origin/<branch-name>

 

Rebase 变基

  1. rebase操作的特点:把分叉的提交历史“整理”成一条直线,看上去更直观。缺点是本地的分叉提交已经被修改过了
  2. rebase操作可以把本地未push的分叉提交历史整理成直线;
  3. rebase的目的是使得我们在查看历史提交的变化时更容易,因为分叉的提交需要三方对比。
git rebase

标签管理

  1. tag就是一个让人容易记住的有意义的名字,它跟某个commit绑在一起,
  2. 在Git中打标签非常简单,首先,切换到需要打标签的分支上,git tag <name>就可以打一个新标签
  3. 可以用命令git tag查看所有标签,标签不是按时间顺序列出,而是按字母排序的,用git show <tagname>查看标签信息
  4. 默认标签是打在最新提交的commit上的。有时候,如果忘了打标签,方法是找到历史提交的commit id,然后打上就可以了
  5. git log --pretty=oneline --abbrev-commit,比方说要对add merge这次提交打标签,它对应的commit id是f52c633,敲入命令
  6. ​git tag v0.9 f52c633
  7. 创建带有说明的标签,用-a指定标签名,-m指定说明文字git tag -a <tagname> -m "blablabla..."
  8. 命令git push origin <tagname>可以推送一个本地标签;
  9. 命令git push origin --tags可以推送全部未推送过的本地标签;
  10. 命令git tag -d <tagname>可以删除一个本地标签;
  11. 命令git push origin :refs/tags/<tagname>可以删除一个远程标签
  12. git clone 整个仓库后使用,以下命令就可以取得该 tag 对应的代码了。 
    git checkout tag_name 
    但是,这时候 git 可能会提示你当前处于一个“detached HEAD" 状态。因为 tag 相当于是一个快照,是不能更改它的代码的。如果要在 tag 代码的基础上做修改,你需要一个分支: 
    git checkout -b branch_name tag_name
    这样会从 tag 创建一个分支,然后就和普通的 git 操作一样了。

git tag v1.0
git tag v0.9 f52c633
git tag -a v0.1 -m "version 0.1 released" 1094adb
git tag
git show v0.1

让Git显示颜色,会让命令输出看起来更醒目

$ git config --global color.ui true

此笔记源自廖雪峰的git教程 教程地址

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python Git常用命令大全: Git是现代化的版本控制系统,常被用于软件开发,协作和管理。它允许在开发过程中创建和管理不同的版本,跟踪文件的更改,以及支持团队合作。Python则是一种广泛应用于开发Web应用程序以及数据科学和人工智能领域的高级编程语言。在使用Git时,Python的代码可以与Git进行集成。这里是Python Git常用命令的大全: 1. git init:初始化一个新的 Git 仓库。 2. git clone:从现有的 Git 仓库克隆项目,可以是本地仓库或远端仓库。 3. git add:将文件添加到 Git 仓库中。git add . 可以添加所有更改。 4. git commit:将所有已添加的文件提交到本地 Git 仓库中。 5. git status:查看当前工作目录中 Git 仓库的状态。 6. git log:查看提交记录。 7. git push:将本地 Git 仓库的更改推送到远端仓库。 8. git pull:将远端 Git 仓库的更改拉到本地仓库。 9. git branch:创建新的分支。 10. git checkout:切换分支。 11. git merge:将一个分支的更改合并到另一个分支。 12. git revert:撤销一个提交。 13. git rebase:将一个分支的修改合并到当前分支。 14. git config:配置 Git。 15. git remote:管理远端仓库。 这是Python Git常用命令的大部分命令,但这并不是全部。在使用Git和Python时,这些命令应该是最为重要的。无论是在个人项目中还是团队合作中,这些命令会让你更加高效地使用Git,并保护你的代码免遭不可挽回地灾难。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值