• My Personal Git Tricks Cheatsheet
  • Originally written by Antonin Januska
  • The Nuggets translation Project
  • Permanent link to this article: github.com/xitu/gold-m…
  • Translator: Pingren
  • Proofreader: Zh1an, Badd, Shixi-Li

My personal Git tips memo

Beyond the “basic” commands, everyone has their usual Git tricks. I want to list the commands that I would like to save aliases in.gitconfig. At the end of this article, you can see some interesting git related commands outside of Git! 🙂

Quick to correct

I often forget to commit a file or leave console.log in the file. I hate committing things like deleting console.log. So, I’ll add the file to the staging area as if I were submitting it, and then run the command:

git commit --amend --reuse-message HEAD
Copy the code

This command adds the file to the last commit and reuses the old commit information. I set its alias to Git amend to quickly fix errors.

Note that you can also use git commit –amend –no-edit to achieve the same effect based on the comments below.

Base at the top of the Origin/Master branch

The old branch is usually quite far behind, long enough that I have to be prepared to eliminate compilation errors, CI errors, or resolve conflicts. My favorite command at this point is:

git fetch origin # fetch latest origin
git rebase origin/master
Copy the code

In this way, I overlay the current branch commits on top of the latest version of the Master branch.

Last submission

Sometimes, the git log command produces verbose results. Because of my frequent use of the amend command mentioned above, I tend to look at the last commit record:

git log- 1Copy the code

Check out to an older version of a file (like a lock file!)

Sometimes I corrupt a file that has nothing to do with my branch. This usually happens with lock files (mix.lock, package-lock.json, and so on). Instead of restoring a commit that might contain many other things, I simply “reset” the file back to the old version:

git checkout hashValue mix. The lockCopy the code

Then I can commit fixes!

cherry-pick

I occasionally use this underrated command. When a branch gets old, sometimes it’s easier to just get what you really need out of it than to bring the whole branch up to speed. For example, this branch has redundant code on the UI or back end. In this case, I might just want to pick out a particular commit from the branch:

git cherry-pick hashvalueCopy the code

This will take the commit to the branch you are in. You can also use lists!

Git cherry-pickhashThe value of the secondhashvalue The thirdhashvalueCopy the code

You can also use intervals:

Git cherry-pickhashValue.. The end of thehashvalueCopy the code

Refer to the log

This is an advanced feature, so much so that I rarely use it. I mean, maybe once a year. But it’s good to know about it. Sometimes, I lost commits: I accidentally deleted branches, reset, or modified a commit.

In these cases, it’s nice to know that Reflog exists. It is not a commit log of the branch you are currently on, it is a log of all your commits (including those above the failed branch). However, the log will be pruned over time, so only relevant information will remain.

git reflog
Copy the code

This command will return a log that you can use to pick or base a commit. This is very powerful after using the PIPE pipe command to connect grep.

Bash command alias

In addition to git commands, I also like to use some fun bash aliases to help with my workflow.

The current branch

To get the name of the current branch, I have this alias:

alias git-branch="git branch | sed -n -e 's/^\* \(.*\)/\1/p'"
Copy the code

When I run git-branch or run $(Git-branch) in another command, I get the name of the branch I’m currently in.

Note that based on the comments section, I switched it to git symbolic-ref –short HEAD to achieve the same effect and make the command more readable.

Tracing upstream branches

While I’m sure.gitconfig will fix the problem, I haven’t figured out how yet. When I first run a push command on a new branch, I am always asked to set the trace status of the upstream branch first. I use aliases in this case:

alias git-up="git branch | sed -n -e 's/^\* \(.*\)/\1/p' | xargs git push -u origin "
Copy the code

Now when I run git-up, I can push the current branch and set up the trace status of the upstream branch!

reply

Based on some useful feedback in the comments, I made some changes to the aliases I used.

The current branch

There seem to be many new ways to get the current branch name. If you look up, you’ll see that I used a crazy sed command to get the branch name.

Here’s a new method I used:

alias git-branch="git symbolic-ref --short HEAD"
Copy the code

It works exactly as expected!

If you find any mistakes in your translation or other areas that need to be improved, you are welcome to the Nuggets Translation Program to revise and PR your translation, and you can also get the corresponding reward points. The permanent link to this article at the beginning of this article is the MarkDown link to this article on GitHub.


The Nuggets Translation Project is a community that translates quality Internet technical articles from English sharing articles on nuggets. The content covers Android, iOS, front-end, back-end, blockchain, products, design, artificial intelligence and other fields. If you want to see more high-quality translation, please continue to pay attention to the Translation plan of Digging Gold, the official Weibo, Zhihu column.