- 设置全局用户:
- git config --global user.name "用户名"
- git config --global user.email "邮箱"
- 设置当地/项目用户:
- git config --local user.name "用户名"
- git config --local user.email "邮箱"
- git init 初始化仓库 在目录中执行 git init 就可以创建一个 Git 仓库了. 例如
- mkdir tensorflow-practice
- cd git
- git init
现在你可以看到在你的项目中生成了 .git 这个子目录,这就是你的 Git 仓库了,所有有关你的此项目的快照数据都存放在这里
-
git clone 拷贝一份远程仓库,也就是下载一个项目
命令格式如下: git clone [url] 直接执行命令: git clone https://gitee.com/yangqiantao/tensorflow-practice.git -
tensorflow-practice 项目是作者学习 tensorflow 的记录,欢迎大家 STAR
Git 的工作就是创建和保存自己的项目快照及与之后的快照进行对比
- 添加一个或多个文件到暂存区:git add [file1] [file2] ...
- 添加指定目录到暂存区,包括子目录: git add [dir]
- 添加当前目录下的所有文件到暂存区: git add .
git diff 命令显示已写入暂存区和已经被修改但尚未写入暂存区文件的区别。git diff 有两个主要的应用场景。
- 尚未缓存的改动:git diff
- 查看已缓存的改动: git diff --cached
- 查看已缓存的与未缓存的所有改动:git diff HEAD
- 显示摘要而非整个 diff:git diff --stat
git diff 查看差异
- 显示暂存区和工作区的差异: git diff [file]
- 显示暂存区和上一次提交(commit)的差异: git diff --cached [file] 或 git diff --staged [file]
- 显示两次提交之间的差异: git diff [first-branch]...[second-branch]
- 提交暂存区到本地仓库中: git commit -m [message] ---> [message] 可以是一些备注信息。
- 提交暂存区的指定文件到仓库区: git commit [file1] [file2] ... -m [message]
- -a 参数设置修改文件后不需要执行 git add 命令,直接来提交: git commit -a
命令 git reset [--soft | --mixed | --hard] [HEAD]
- --mixed 为默认,可以不用带该参数,用于重置暂存区的文件与上一次的提交(commit)保持一致,工作区文件内容保持不变。
- 命令: git reset [HEAD]
- git reset HEAD^ # 回退所有内容到上一个版本
- git reset HEAD^ 修改的文件XXX # 回退 XXX 文件的版本到上一个版本
- git reset 052e # 回退到指定版本
- --soft 参数用于回退到某个版本:
- 命令:git reset --soft HEAD
- 实例: git reset --soft HEAD~3 # 回退上上上一个版本
- --hard 参数撤销工作区中所有未提交的修改内容,将暂存区与工作区都回到上一次版本,并删除之前的所有信息提交
- 命令 git reset --hard HEAD 实例:
- git reset –hard HEAD~3 # 回退上上上一个版本
- git reset –hard bae128 # 回退到某个版本回退点之前的所有信息。
- git reset --hard origin/master # 将本地的状态回退到和远程的一样
- 删除本地文件
-
将文件从暂存区和工作区中删除: git rm file
如果删除之前修改过并且已经放到暂存区域的话,则必须要用强制删除选项 -f: git rm -f file -
如果想把文件从暂存区域移除,但仍然希望保留在当前工作目录中,换句话说,仅是从跟踪清单中删除,使用 --cached 选项即可: git rm --cached file
-
文件从暂存区域移除,但工作区保留:git rm --cached xxx
-
可以递归删除,即如果后面跟的是一个目录做为参数,则会递归删除整个目录中的所有子目录和文件:git rm –r *
- 删除远程文件
- 预览将要删除的文件
git rm -r -n --cached 文件/文件夹名称
-n 这个参数,执行命令时,是不会删除任何文件,而是展示此命令要删除的文件列表预览。
- 确定无误后删除文件
git rm -r --cached 文件/文件夹名称
- 提交到本地并推送到远程服务器
git commit -m "提交说明"
git push origin master
git mv 命令用于移动或重命名一个文件、目录或软连接。
git mv [file] [newfile]
如果新文件名已经存在,但还是要重命名它,可以使用 -f 参数:
git mv -f [file] [newfile]
- git log 命令列出历史提交记录
- git log --oneline 选项, 来查看历史记录的简洁的版本
- git log --graph 选项, 查看历史中什么时候出现了分支、合并
- git log --reverse 参数来逆向显示所有日志
- git log --author=username 查找指定用户的提交日志
- git remote -v 显示所有远程仓库
gitee https://gitee.com/yangqiantao/Git_Practice.git (fetch)
gitee https://gitee.com/yangqiantao/Git_Practice.git (push)
github https://github.com/NigeloYang/Git_Practice.git (fetch)
github https://github.com/NigeloYang/Git_Practice.git (push)gitee/github 为远程地址的别名 可以自定义别名。
- git remote show url # 显示某个远程仓库的信息
- git remote add 仓库别名 url # 添加远程版本库
- git remote rm name # 删除远程仓库
- git remote rename old_name new_name # 修改仓库名
- git fetch 命令执行完后需要执行 git merge 远程分支到你所在的分支,具体执行步骤
- git fetch origin
- git merge origin/master
git pull 命令用于从远程获取代码并合并本地的版本。
git pull 其实就是 git fetch 和 git merge FETCH_HEAD 的简写。
命令格式如下: git pull <远程主机名> <远程分支名>:<本地分支名>
更新操作:
- git pull
- git pull origin
将远程主机 origin 的 master 分支拉取过来,与本地的 brantest 分支合并。
git pull origin master:brantest
如果远程分支是与当前分支合并,则冒号后面的部分可以省略。
git pull origin master
git push 命用于从将本地的分支版本上传到远程并合并。
命令格式如下:
git push <远程主机名> <本地分支名>:<远程分支名>如果本地分支名与远程分支名相同,则可以省略冒号
git push <远程主机名> <本地分支名>
以下命令将本地的 master 分支推送到 origin 主机的 master 分支。
git push origin master git push
相等于:
git push origin master:master
如果本地版本与远程版本有差异,但又要强制推送可以使用 --force 参数:
git push --force origin master
删除主机的分支可以使用 --delete 参数,以下命令表示删除 origin 主机的 master 分支:
git push origin --delete master
- 创建分支 git branch branchname
- 切换分支 git checkout branchname
- 创建并切换到分支,相当于 2 和 1 加起来 git checkout -b branchname
- git branch 查看所有的分支信息 ,当前分支前带有*
- git branch –-all 查看所有的分支信息
- git branch -d branchname 删除本地分支
- git push origin --delete branchname 删除远程库上的分支
- git push origin :branchname 简短的命令来远程删除分支
切换到想要合并的分支,执行git merge branchname
例如 master分支 和并 dev 分支 只需要执行
-
git checkout master
-
git merge dev
-
推送分支 git push origin master 把该分支上的本地提交推送到远程库
-
git push origin branchName 推送其他分支
本地项目代码关联远程仓库并提交,命令如下:
- git init
- git remote add origin 项目地址
- git pull origin master
- git add .
- git commit -am 'message'
- git push origin master
- git clone 项目地址
- 修改文件
- git add .
- git commit -am 'message'
- git push
- 方式一:定义不同的远程仓库名称,然后分别推送 多次推送,配了几个远程仓库就推送几次
- 方式二:在同一个远程仓库下添加另一个远程仓库的地址,然后推送 only一次推送
- 可以直接通过命令将 本地项目 和 gitee/GitHub 项目关联
- git remote add gitee gitee项目地址
- git remote add github github项目地址
- 也可以通过修改本地项目的配置文件
- 首先,进入到项目的 .git 文件夹,打开 config 文件
- 然后,找到 [remote "origin"] ,复制一份remote到下面,修改 remote 的名字和 url 即可
例如
[core]
repositoryformatversion = 0
filemode = false
bare = false
logallrefupdates = true
symlinks = false
ignorecase = true[remote "gitee"]
url = https://gitee.com/yangqiantao/tensorflow-practice.git
fetch = +refs/heads/:refs/remotes/origin/[remote "github"]
url = https://github.com/NigeloYang/tensorflow-practice.git
fetch = +refs/heads/:refs/remotes/origin/[branch "master"]
remote = origin
merge = refs/heads/master
- 执行以下命令: git remote,可以看到配置的两个仓库
- 推送代码时,需要对两个仓库分别执行一次push命令,也就是多次推送
推送 git push gitee master
获取 git pull gitee master
推送 git push github master
获取 git pull github master
- 通过命令将 gitee/github 项目地址添加到本地已有的remote下
- git remote set-url --add origin gitee/github项目地址
- 也可以通过修改本地项目的配置文件
- 推送代码只需执行以下一条命令即可 git push
例如
[core]
repositoryformatversion = 0
filemode = false
bare = false
logallrefupdates = true
symlinks = false
ignorecase = true[remote "origin"]
url = https://gitee.com/yangqiantao/tensorflow-practice.git
url = https://github.com/NigeloYang/tensorflow-practice.git
fetch = +refs/heads/:refs/remotes/origin/[branch "master"]
remote = origin
merge = refs/heads/master