How can I check out a particular version of one file in Git?

How can I check out a particular version of one file in git?

I found this mail on the mailing list, which said:

  • Re-doing a reverted merge in Git
  • Eclipse + Git - How to get toolbar?
  • Partial sharing of git repositories
  • Is there a reason why you shouldn't mix ssh and smart http access with git?
  • What does “would be overwritten by merge” mean?
  • OpenSSL errno 10054,connection refused, whilst trying to connect to our server
  • $ git checkout HEAD~43 Makefile
    $ git reset Makefile

    But I don’t understand how to find out ‘HEAD~43’, if I do a git log aFile, how can I find out which ‘HEAD~43’ I should use?

    And why do I need to run git reset for that file? What does it do?

  • Gerrit Change has Status:Submitted, Merge Pending, how to solve it?
  • Pipes in a git Alias?
  • How to list all Git tags?
  • How to merge a successful build of a pull request using a Jenkinsfile
  • Pushing from GitHub to a Web Server
  • Tput color definitions for windows git shell
  • 3 Solutions collect form web for “How can I check out a particular version of one file in Git?”

    You know what commit (ie: the specific revision) the file belongs to? Then do:

    git checkout <commit> <file>

    The other command:

    git checkout HEAD~N <file>

    Is for when you want to get a version of the file from a range back (which I do for nostalgia).

    HEAD~43 is just treeish, so you can use a hash or a tag. You have to separate treeish from the filename with --, otherwise it is treated as filename. For example.

    git checkout v0.45 -- filename
    git checkout HEAD^ -- filename
    git checkout 16bb1a4eeaa9 -- filename

    HEAD~43 refers to the commit (version) of the file. Instead of that, you can use the commit hash you get from doing git log on the file. If you just want the file, you don’t need to run git reset on it; that’s only necessary if you want to forward-port the file to the current HEAD.

    Git Baby is a git and github fan, let's start git clone.