Git本地倉庫基本操作

設置姓名和郵箱

設置使用Git時的姓名和郵箱地址。名字須用英文輸入
git config --global user.name "chuyaoxin"
git config --global user.email "[email protected]"

命令運行的結果是在“C:\Users\用戶名”路徑下,產生一個.gitconfig文件,可以用記事本打開。

想更改這些信息時,可以直接編輯這個設置文件。這裏設置的姓名和郵箱地址會用在Git的提交日誌中。由於在GitHub上公開倉庫時,這裏的姓名和郵箱地址也會隨着提交日誌一同被公開,所以請不要使用不便公開的隱私信息。

創建倉庫

創建一個新文件夾,比如“TestForGit”
然後右鍵點擊這個文件夾,選擇Git Bash Here
打開後,輸入git init完成代碼倉庫的建立

輸入ls -al可以看到目錄下有個.git的文件夾,但這個目錄默認是隱藏的。

提交本地代碼

先用add命令把要提交的內容都加進來,然後commit纔是真的去執行提交操作。
第一步,用命令git add告訴Git,把文件添加到倉庫
git add readme.txt
第二步,用命令git commit告訴Git,把文件提交到倉庫
git commit -m "write a readme file"

.gitignore

.gitignore是Git的忽略配置文件,放在項目根目錄下就行,這樣在提交代碼時就不會跟蹤在.gitignore配置文件列舉的文件。另外,.gitignore文件本身需要被git跟蹤管理,不能被忽略。

git add

用途:可以用來跟蹤新文件,或者添加已被修改的跟蹤的文件到緩存區,或者把合併的衝突文件標記爲已解決
git add的原意是更新當前工作目錄樹修改的內容到索引中(也就是緩存中去)
主要針對兩種文件:(1)版本庫沒有跟蹤的文件(2)版本庫已經跟蹤,但是修改了的文件
另外git add會自動忽略.gitignore文件所忽略的文件。

  • git add .
    將文件的修改、文件的新建(注意!不包括被刪除的文件),添加到暫存區
    git add .會把所有untrack的文件都加入暫存區,並且會根據.gitignore做過濾
  • git add *
    git add *會忽略.gitignore把任何文件都加入暫存區
  • git add -u
    將文件的修改、文件的刪除(注意!僅監控被add的文件,不包括新文件),添加到暫存區,u表示update
  • git add -A
    將文件的修改,文件的刪除,文件的新建(相當於add .與add -u的合集),添加到暫存區,A表示all
  • 其他
    可以使用git add -h命令來查看
$ git add -h
usage: git add [<options>] [--] <pathspec>...
    -n, --dry-run         dry run
    -v, --verbose         be verbose
    -i, --interactive     interactive picking
    -p, --patch           select hunks interactively
    -e, --edit            edit current diff and apply
    -f, --force           allow adding otherwise ignored files
    -u, --update          update tracked files
    --renormalize         renormalize EOL of tracked files (implies -u)
    -N, --intent-to-add   record only the fact that the path will be added later
    -A, --all             add changes from all tracked and untracked files
    --ignore-removal      ignore paths removed in the working tree (same as --no-all)
    --refresh             don't add, only refresh the index
    --ignore-errors       just skip files which cannot be added because of errors
    --ignore-missing      check if - even missing - files are ignored in dry run
    --chmod (+|-)x        override the executable bit of the listed files
    --pathspec-from-file <file>
                          read pathspec from file
    --pathspec-file-nul   with --pathspec-from-file, pathspec elements are separated with NUL character

git commit

  • git commit -m "write a readme file"

    可以在使用了多次git add之後再使用git commit來提交。
    在git commit命令中,-m後面輸入的是本次提交的說明,可以輸入任意內容,但最好是有意義的,這樣就能從歷史記錄裏方便地找到改動記錄。
    執行成功後,從圖中可以看出,一個文件被改動,插入了6行內容。

git status

  • git status
    可以使用git status命令查看是否還有文件未提交

    上圖說明當前文件都已正常提交。
    如果我對上傳的文件進行修改,但是卻不提交會如何?

    會報出如上所示的錯誤!modified: readme.txt no changes added to commit
    字面意思:readme.txt被修改,提交沒有變化

git diff

  • git diff readme.txt
    git status可以讓我們知道有沒有正常提交,比如上面那個例子,但如果要查看文件到底修改了什麼內容,可以使用git diff 文件名命令

    這條命令將我對這個文件的修改記錄顯示了出來

查看提交記錄

  • git log
    使用git log即可查看歷史提交信息

    從這張圖也可以看出之前git commit -m "write a readme file"中,-m部分的作用,這個和編程時寫註釋是一樣的,可以不寫,但是寫的話方便以後的工作。
    還有要注意的地方是輸出的結果,
    顯然我這是提交了兩次,以第一次的結果爲例,

commit 418ee0fc27d78a71f5869451b5a1599cc028b0ca (HEAD -> master)
Author: chuyaoxin [email protected]
Date: Tue Aug 4 19:48:59 2020 +0800
write a readme file

對應的含義分別是

此次提交對應的版本號
提交人:姓名 郵箱
提交的時間
提交版本修改的內容:就是我們git commit -m “xxx”裏的xxx

撤銷未提交的修改

如果對文件進行了錯誤的修改,且已經Ctrl+S保存,但還沒有提交,想要撤銷之前的修改可以使用checkout命令

  • 不僅未提交,而且沒有add
    如果是這種情況,只需要一句git checkout 修改的文件名即可
    例如,git checkout readme.txt

    此時,再打開readme.txt,我對此文件的第二次修改被取消掉了
  • 已經add,但還沒有提交
    如果我們已經add了的話,那麼直接checkout是沒任何作用的,我們要先取消添加纔可以撤回提交
    git reset HEAD readme.txt
    git checkout readme.txt

版本回退

  • git reset
    如果我們已經提交,但想退回到之前的版本,可以使用git reset命令
    比如我先在readme.txt中添加了一行,然後git add readme.txtgit commit -m "add the third step",添加並提交到倉庫
    完成之後,使用git log檢查提交記錄。

    PS:通過這張圖也能看出,最新的版本號顯示在最上方
  • git reset --hard HEAD
    在git中,HEAD表示當前版本,HEAD表示上一個版本,HEAD^表示上上個版本
    退回到上一個版本需要依次輸入以下指令
    git reset --hard HEAD
    git reset --hard HEAD^
    執行結果如下圖所示:

    再輸入git log查看,此時的版本號已經發生了變化,最新修改的那個版本號沒有顯示出來了
  • git reset --hard 版本號
    這條命令可以讓我們將當前版本更改爲存在過的任意一個版本
    同時仔細觀察這張圖,

    可以很容易的猜到,其實版本號只要輸入前七位就可以了
    所以我們之前的回退指令可以用這條來替代,
    git reset --hard 418ee0f
  • git reflog
    如果你版本回退之後發現,還是最新的那個版本好一點,但此時通過git log已經找不到那個版本號了,
    可以使用git reflog

    顯然,版本回退之前的最新版本號爲14a5f92
    然後使用git reset --hard 14a5f92
    打開readme.txt,因爲版本回退而去掉的修改又回來了
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章