git常用命令

创建分支

$ git checkout -b dev
Switched to a new branch 'dev'

git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:

$ git branch dev
$ git checkout dev
Switched to branch 'dev'

例如在原来的master分支上进行了修改,并不提交,然后使用git checkout -b lab1命令可以创建并切换到lab1分支,然后将修改进行commit,然后执行git push origin lab1就可以看到修改的提交到了lab1分支了,原来的master分支没有修改。

查看分支

用git branch命令查看当前分支【本地分支】:

$ git branch
* dev
  master

使用git branch -r 查看对应的【】远程分支】:

$ git branch -r
  origin/local-v2.0

这是会看到master和dev,而且dev上会有一个星号,这个时候dev是一个本地分支,远程仓库不知道它的存在。

本地分支可以不同步到远程仓库,我们可以在dev开发,然后merge到master,使用master同步代码,当然也可以同步

git branch --all  
# 默认只有master分支,所以会看到如下两个分支
# master[本地主分支] 
# origin/master[远程主分支]
# 新克隆下来的代码默认master和origin/master是关联的,也就是他们的代码保持同步
从远端拉取分支,并切换
$ git checkout -b springboot origin/springboot
Switched to a new branch 'springboot'
Branch 'springboot' set up to track remote branch 'springboot' from 'origin'.
如果出现如果出现fatal: Cannot update paths and switch to branch 'dev2' at the same time. Did you intend to checkout 'origin/dev2' which can not be resolved as commit?

表示拉取不成功。我们需要先执行

git fetch

然后再执行

git checkout -b 本地分支名 origin/远程分支名

即可。

切换分支

$ git checkout master
Switched to branch 'master'
发布到远端分支
git push origin dev  # 这样远程仓库也有一个dev分支了
git push origin 远端分支名

发布dev分支指的是同步dev分支的代码到远程服务器

在dev分支开发代码

git checkout dev  # 切换到dev分支进行开发
# 开发代码之后,我们有两个选择
# 第一个:如果功能开发完成了,可以合并主分支
git checkout master  # 切换到主分支
git merge dev  # 把dev分支的更改和master合并
git push  # 提交主分支代码远程
git checkout dev  # 切换到dev远程分支
git push  # 提交dev分支到远程
# 第二个:如果功能没有完成,可以直接推送
git push  # 提交到dev远程分支
# 注意:在分支切换之前最好先commit全部的改变,除非你真的知道自己在做什么

删除远程分支

我们用git branch -r查看远程分支,查看到有两个分支local-v2.0master,我们想删除master分支。

# origin 表示远程仓库的别名
git push origin --delete master

删除远程仓库

使用命令git remote -v可以查看到远程仓库:

old-origin	http://192.168.1.100:81/user1/shenzhen.git (fetch)
old-origin	http://192.168.1.100:81/user1/shenzhen.git (push)
origin	http://192.168.1.101/user1/shenzhen.git (fetch)
origin	http://192.168.1.101/user1/shenzhen.git (push)

我们想删除origin对应的仓库地址,使用命令:

git remote remove origin

这样再通过git remote -v查看仓库:

old-origin	http://192.168.1.100:81/user1/shenzhen.git (fetch)
old-origin	http://192.168.1.100:81/user1/shenzhen.git (push)

修改分支名称(包括本地和远程分支)

git branch -m old_branch new_branch # Rename branch locally 
git push origin :old_branch # Delete the old branch
git push --set-upstream origin new_branch # Push the new branch, set local branch to track the new remote

设置免密登录

git解决每次拉取代码都需要用户名密码。

在命令行里执行git config --global credential.helper store,这会在gitconfig目录下创建一个文件,用于记录账号和密码;

再执行一次git pull,输入正确的账号密码,以后就不用再输了

查看远端分支

$ git remote -v
origin  http://192.168.152.39/duandingyang/shenzhen.git (fetch)
origin  http://192.168.152.39/duandingyang/shenzhen.git (push)

添加远端分支

git remote add origin https://github.com/vincentduan/selfweixin.git

其中origin就是为远端仓库所起的名字,一般叫做origin,其实你也可以叫做jack或者Rose什么的,后面的https://github.com/vincentduan/selfweixin.git就是你的远端仓库的真实地址。

git添加两个分支

由于当前项目已经有一个远端分支,根据需要需要添加另一个远端分支。

首先需要在远端创建一个仓库:test-python

需要注意的是,添加一个远端分支名字不能是origin。

git remote add remote_iie4bu http://IP:81/test/test-python.git

然后查看,可以看到有两个远端分支:

$ git remote -v
origin  https://gitee.com/jack/test-python.git (fetch)
origin  https://gitee.com/jack/test-python.git (push)
remote_iie4bu   http://IP:81/jack/test-python.git (fetch)
remote_iie4bu   http://IP:81/jack/test-python.git (push)

使用git push remote_iie4bu 本地分支名就可以推送到远端分支remote_iie4bu
使用git pull remote_iie4bu 本地分支名就可以将远端分支拉取到本地了

git pull

git pull使用说明
git pull命令用于从另一个存储库或本地分支获取并集成(整合)。git pull命令的作用是:取回远程主机某个分支的更新,再与本地的指定分支合并,它的完整格式稍稍有点复杂。
使用语法

git pull [options] [<repository> [<refspec>…]]
描述

将远程存储库中的更改合并到当前分支中。在默认模式下,git pull是git fetch后跟git merge FETCH_HEAD的缩写。

更准确地说,git pull使用给定的参数运行git fetch,并调用git merge将检索到的分支头合并到当前分支中。 使用–rebase,它运行git rebase而不是git merge。
示例
以下是一些示例 -

$ git pull <远程主机名> <远程分支名>:<本地分支名>
比如,要取回origin主机的next分支,与本地的master分支合并,需要写成下面这样 -
$ git pull origin next:master
如果远程分支(next)要与当前分支合并,则冒号后面的部分可以省略。上面命令可以简写为:
$ git pull origin next
上面命令表示,取回origin/next分支,再与当前分支合并。实质上,这等同于先做git fetch,再执行git merge。

$ git fetch origin
$ git merge origin/next

在某些场合,Git会自动在本地分支与远程分支之间,建立一种追踪关系(tracking)。比如,在git clone的时候,所有本地分支默认与远程主机的同名分支,建立追踪关系,也就是说,本地的master分支自动”追踪”origin/master分支。
Git也允许手动建立追踪关系。
$ git branch --set-upstream master origin/next
上面命令指定master分支追踪origin/next分支。
如果当前分支与远程分支存在追踪关系,git pull就可以省略远程分支名。
$ git pull origin
上面命令表示,本地的当前分支自动与对应的origin主机”追踪分支”(remote-tracking branch)进行合并。

如果当前分支只有一个追踪分支,连远程主机名都可以省略。

$ git pull
上面命令表示,当前分支自动与唯一一个追踪分支进行合并。

如果合并需要采用rebase模式,可以使用–rebase选项。

$ git pull --rebase <远程主机名> <远程分支名>:<本地分支名>
git fetch和git pull的区别

git fetch:相当于是从远程获取最新版本到本地,不会自动合并。

$ git fetch origin master
$ git log -p master..origin/master
$ git merge origin/master

以上命令的含义:

首先从远程的origin的master主分支下载最新的版本到origin/master分支上

然后比较本地的master分支和origin/master分支的差别

最后进行合并

上述过程其实可以用以下更清晰的方式来进行:

$ git fetch origin master:tmp
$ git diff tmp 
$ git merge tmp
  1. git pull:相当于是从远程获取最新版本并merge到本地

git pull origin master

上述命令其实相当于git fetch 和 git merge
在实际使用中,git fetch更安全一些,因为在merge前,我们可以查看更新情况,然后再决定是否合并。

git reset
git reset就是当我们提交了错误的内容后进行回退使用的命令。

git reset 版本号,就是回退到该版本号上。

git reset --hard 命令可以把本地的所有修改都进行撤销。慎用!

git只拉取项目中的某个目录

使用 sparse clone 实现部分代码的拉取

假设我的项目目录是:

--my_project
  --proj1
  --proj2
  --proj3
  --proj4

现在我只想在服务器上拉取 proj2 目录下的东西。

$ mkdir my_project
$ cd my_project
$ git init
  Initialized empty Git repository in /home/user1/lib/username/.git/
$ git remote add -f origin http://xxx/user_name/my_project.git  #拉取remote的all objects信息
Updating origin
remote: Counting objects: 1141, done.
remote: Compressing objects: 100% (591/591), done.
remote: Total 1141 (delta 659), reused 871 (delta 491)
Receiving objects: 100% (1141/1141), 2.65 MiB | 10.07 MiB/s, done.
Resolving deltas: 100% (659/659), done.
From http://xxx/user_name/my_project
 * [new branch]      local-v2.0 -> origin/local-v2.0

$ git config core.sparsecheckout true   #开启sparse clone
# 默认没有sparse-checkout文件
$ echo "proj2" >> .git/info/sparse-checkout   #设置需要pull的目录,*表示所有,!表示匹配相反的

$ less .git/info/sparse-checkout
  proj2
$  git pull origin local-v2.0 #拉取
$ ls
 proj2

假如还想要拉取其他文件或者目录的话,可以通过 git sparse-checkout add 命令来添加。
这就实现了,远程仓库和云服务器仓库之间的定制化同步,需要什么目录和文件就同步什么目录和文件,不需要的可以统统不要。

  • git sparse-checkout disable表示禁用 git sparse-checkout
  • git sparse-checkout reapply表示重新启用git sparse-checkout

git 设置origin 默认上传url

当前远程分支情况如下:

$ git remote -v
gitee   https://gitee.com/jack/proj_1.git (fetch)
gitee   https://gitee.com/jack/proj_1.git (push)
origin  http://my_ip/rose/proj_1.git (fetch)
origin  http://my_ip/rose/proj_1.git (push)

我们输入git push时,默认会推送到origin对应的http://my_ip/rose/proj_1.git路径下。我们希望的是,输入git push可以推送到https://gitee.com/jack/proj_1.git下。

  1. 使用命令git remote set-url origin https://gitee.com/jack/proj_1.gitorigin连接到https://gitee.com/jack/proj_1.git下。这样我们输入git remote -v得到:
$ git remote -v
gitee   https://gitee.com/jack/proj_1.git (fetch)
gitee   https://gitee.com/jack/proj_1.git (push)
origin  https://gitee.com/jack/proj_1.git (fetch)
origin  https://gitee.com/jack/proj_1.git (push)

这将更改origin的URL,使其指向我想要提交的远程存储库。现在,当您运行git push命令时,它将默认将更改推送到https://gitee.com/jack/proj_1.git

  1. 使用以下命令将gitee删除:git remote remove gitee。输出如下:
origin  https://gitee.com/jack/proj_1.git (fetch)
origin  https://gitee.com/jack/proj_1.git (push)
  1. 从新添加新的分支:git remote add my_remote http://my_ip/rose/proj_1.git。输入命令git remote -v
my_remote http://my_ip/rose/proj_1.git (fetch)
my_remote http://my_ip/rose/proj_1.git (push)
origin  https://gitee.com/jack/proj_1.git (fetch)
origin  https://gitee.com/jack/proj_1.git (push)

修改origin名称

需求:

目前我们有一个项目从http://192.168.1.100/proj1.git拉取的。
我们想要把这个项目迁移到http://192.168.1.101/proj1.git上。

执行命令:

cd proj1
git remote rename origin old-origin
git remote add origin http://192.168.1.101/proj1.git
git push --set-upstream origin --all
git push --set-upstream origin --tags

git push --set-upstream origin --all 这个命令的含义是将本地的所有分支推送到远程仓库,并且设置这些分支的上游分支(upstream branch)为远程仓库的同名分支。这通常用于首次将本地仓库的分支与远程仓库进行关联,以后可以使用简化的 git push 命令来推送更改而不需要再指定远程分支。

具体解释如下:

  • git push: 这是用于将本地更改推送到远程仓库的 Git 命令。
  • --set-upstream: 这个选项告诉 Git 在推送时设置本地分支与远程分支之间的关联。
  • origin: 这是远程仓库的名称,通常情况下,“origin” 是默认的远程仓库名称,代表了你的代码托管服务(如 GitHub、GitLab、Bitbucket)上的仓库。
  • --all: 这个选项告诉 Git 推送所有本地分支到远程仓库。

因此,当你运行这个命令后,Git 会将所有本地分支的更改推送到远程仓库,并且为每个本地分支设置相应的上游分支,以后你可以使用 git push 来推送更改,Git 将自动知道要将更改推送到哪个远程分支。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
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,并保护你的代码免遭不可挽回地灾难。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值