git常用操作

2020-03-27  本文已影响0人  crazy汤姆猫

ignore
在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改根目录中 .gitignore 文件的方法(如无,则需自己手工建立此文件)。这个文件每一行保存了一个匹配的规则。
例如:

此为注释 – 将被 Git 忽略

.a # 忽略所有 .a 结尾的文件
!lib.a# 但 lib.a 除外
/TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/# 忽略 build/ 目录下的所有文件
doc/
.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt
规则很简单,不做过多解释,但是有时候在项目开发过程中,突然心血来潮想把某些目录或文件加入忽略规则,按照上述方法定义后发现并未生效,原因是.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。那么解决方法就是先把本地缓存删除(改变成未track状态),然后再提交:
git rm -r --cached .
git add .
git commit -m 'update .gitignore

git archive --format zip --output "./tk.zip" tk(or commit)

git clean -fd 去除untrack文件

git .gitignore 配置忽略文件

git ignore files

ingnore self

.gitignore
UserInterfaceState.xcuserstate
.DS_Store
xcshareddata/
xcschememanagement.plist
Breakpoints_v2.xcbkptlist
build/

工作区管理
git checkout -- filename 放弃当前工作区的filename文件,两种情况:暂存区有add,则回到暂存区状态,否则直接放弃到原来的状态
git checkout -- filename 工作区被删除的文件同样可以使用该命令恢复
git chekout . 放弃当前工作区,状态同上

版本回退
git reflog查看命令历史
git log可以查看提交历史
git reset --hard commit_id 回退到某个版本
git reset --hard HEAD^ 回退到上个版本

分支操作
git push --delete origin/branch 删除远程分支
git branch -b loaclbranch origin/remotebranch 克隆远程分支到本地

tag操作
git tag tagname 创建本地tag
git push origin tagname 推送tag到远程
git push origin :refs/tags/tagname 删除远程tag
git push origin --tags 一次性推送全部tag到远程

上一篇 下一篇

猜你喜欢

热点阅读