四时宝库

程序员的知识宝库

Git的8种高级用法,节省你的时间和头痛

Git作为开发者入门第一的工具大家在日常肯定经常使用,但是这里我要分享一些Git的高级用法用来节省你的时间跟头痛。


1. 在Git中搜索

如果你想在存储库中寻找可能早已经被删除的代码,使用以下命令可以在任何提交或分支中搜索代码。

git rev-list --all | xargs git grep -F ''

例如,要搜索字符串"jwt_black_list"在你的git仓库:

$git rev-list --all | xargs git grep -F 'jwt_black_list'
6b8b51184e5ec0efaf145a05241358bf1ac77be7:config/config.go:      JwtBlackList int64 `mapstructure:"jwt_black_list" json:"jwt_black_list" yaml:"jwt_black_list"`
6b8b51184e5ec0efaf145a05241358bf1ac77be7:utils/jwt.go:  return "jwt_black_list:" + MD5([]byte(tokenStr))

2. 清理本地分支

删除已经从远程存储库中删除的本地分支

git config --global fetch.prune true

删除已合并到 master 分支的所有本地分支

git branch --merged master | grep -v '^\*\| master' | xargs -n 1 git branch -d

3. 计算commit

git rev-list --count branch_name

计算main分支提交的次数

$ git rev-list --count main                                                                                                                       128 ?  10:28:12 
30

4. 查看另一个分支的文件

通常我们会想要查看存在于另一个分支上的文件的内容。实际上,我们可以在不切换分支或通过 查看git 存储库管理器的情况下做到这一点。

例如,如果您在我们的master分支中有一个文件“newfeature.py”,但我们正在处理我们的dev分支,它已经落后了。我们可以使用以下命令查看这个新文件

$ git show master:newfeature.py

5. 空白提交

如果正在使用 DevOps 管道和 CI/CD,那么很可能在 git 提交上有自动集成。实际上我们可以只使用空白提交,而不用对文档进行小的行更改。

git commit --allow empty -m 'new empty commit'

6. 自动更正拼写错误

我们在使用git命令都会打错命令或者看到这条信息出现在终端上。

git: ‘stats’ is not a git command. See ‘git --help’.
The most similar command is
status

Git 实际上提供了自动更正命令的配置。

git config --global help.autocorrect 1

7. 自动修剪

Git Prune 是一个实用命令,用于清理任何引用都无法访问的孤立 git 对象。任何无法通过标签或分支访问的提交都被定义为不可访问。Git prune 是一个 git 命令,它将清除所有这些对象。当然,很难知道何时需要修剪已删除的对象,因为我们的存储库不会警告我们。通过启用这个 git 配置,我们可以要求 git 对每个 git fetch 和 git pull 执行修剪

$ git config --global fetch.prune true

8. 备份未跟踪的文件

当要删除一些未跟踪的文件时但是怕以后需要这些文件,可以创建这些文件的备份以防万一。

git ls-files --others --exclude-standard -z | xargs -0 tar rvf ~/backup-untracked.zip

发表评论:

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言
    友情链接