天天看点

Git基础入门(三)Git基本操作

获取 Git 仓库的两种方式:

    第一种是在现有项目或目录下导入所有文件到Git中

    第二种是从一个服务器克隆一个现有的Git仓库

初始化Git仓库:

    git init                #使Git能够管理当前目录(初始化)

    1、该命令将创建一个名为.git的子目录,这个子目录含有你初始化的Git仓库中所有的必须文件,这些文件是 Git 仓库的骨干

    2、如果你是在一个非空目录中初始化Git仓库来进行版本控制的话,你应该开始跟踪这些文件并提交

        git add *.py                 #跟踪当前目录下的所以.py文件(将文件放入暂存区域)                                      

        git commit -m 'version1'     #提交-m指定附加信息(将文件提交至Git仓库)

克隆现有的仓库

    如果想获得一份已存在的Git仓库,需要用到git clone命令,Git克隆的是该Git仓库服务器上的几乎所有数据,而不是仅仅复制完成你的工作所需要文件

    当执行git clone命令的时候,默认配置下远程Git仓库中的每一个文件的每一个版本都将被拉取下来

    如果你的服务器的磁盘坏掉了,你可以使用任何一个克隆下来的用户端来重建服务器上的仓库

    git clone [url]

    例:git clone https://github.com/libgit2/libgit2

    这会在当前目录下创建一个名为libgit2的目录,并在这个目录下初始化一个.git目录,从远程仓库拉取下所有数据放入libgit2目录

    git clone https://github.com/libgit2/libgit2 mylibgit

    这将执行与上一个命令相同的操作,不过在本地创建的仓库名字变为mylibgit。

工作目录下的每一个文件都只有两种状态:已跟踪或未跟踪

    已跟踪的文件指的是那些被纳入了版本控制的文件,在上一次快照中有它们的记录,在工作一段时间后,它们的状态可能处于未修改,已修改或已放入暂存区

    工作目录中除了已跟踪文件以外的所有其它文件都属于未跟踪文件,它们既不存在于上次快照的记录中,也没有放入暂存区

Git文件的生命周期:

    编辑过某些文件之后,由于自上次提交后你对它们做了修改,Git将它们标记为已修改文件

    我们将这些修改过的文件放入暂存区,然后提交所有暂存了的修改

检查当前文件状态

    git status              #查看Git仓库所以文件的状态

例:git status

    On branch master                                            #当前使用的Git分支(分支名称:master)

    nothing to commit, working directory clean                  #没有需要提交的文件(即当前目录从上一次提交之后没有发生任何改变)

例:echo 'My Project' > test.py

   git status

      On branch master

      Untracked files:                            #表示工作目录下面存在为跟踪的文件或目录

      (use "git add <file>..." to include in what will be committed)

          test.py                                 #显示为跟踪的文件或目录

      nothing added to commit but untracked files present (use "git add" to track)

      未跟踪的文件意味着Git在之前的快照中没有这些文件,Git 不会自动将之纳入跟踪范围,除非你明明白白地告诉它"我需要跟踪该文件"

跟踪新文件

    git add test.py

    此时再运行git status命令,会看到test.py文件已被跟踪,并处于暂存状态:

    git status

      Changes to be committed:                  #表示有需要提交的修改

        (use "git reset HEAD <file>..." to unstage)

          new file:  test.py                    #新文件(即以前快照中不存在的文件)  

暂存已修改文件

    git commit -m 'version-1'                       #提交前面的操作

    echo '#!/usr/bin/env python' > test.py          #修改test.py文件内容

        On branch master

        Changes not staged for commit:                  #未提交的跟改

          (use "git add <file>..." to update what will be committed)

          (use "git checkout -- <file>..." to discard changes in working directory)

            modified:   test.py                         #修改后的文件或目录

    git add test.py                     #将修改后的文件放入暂存区

          modified:   test.py                   #修改后的文件或目录

    现在文件处于已暂存,下次提交时就会记录到仓库,此时如果,你更改了test.py的文件内容

    echo '#coding:utf-8' >> test.py             #修改test.py文件内容

        Changes to be committed:

            modified:   test.py

        Changes not staged for commit:

        (use "git add <file>..." to update what will be committed)

        (use "git checkout -- <file>..." to discard changes in working directory)

    现在test.py文件同时出现在暂存区和非暂存区,实际上Git只不过暂存了你运行git add命令时的版本

    所以,运行了git add之后又作了修订的文件,需要重新运行git add把最新版本重新暂存起来

    git commit -m 'version-2'               #提交更新(如果不使用-m选项时会出现一个默认编辑器让你输入更新的标记信息)

    git add是个多功能命令,可以用它跟踪新文件,或者把已跟踪的文件放到暂存区,还能用于合并时把有冲突的文件标记为已解决状态等

git status -s:

    git status命令的输出十分详细,但其用语有些繁琐。使用 git status -s 命令将得到一种更为紧凑的格式输出

    新添加的未跟踪文件前面有 ?? 标记

    新添加到暂存区中的文件前面有 A 标记

    修改过的文件前面有 M 标记

        例:M test.py

            M  test.py

    M有两个可以出现的位置,出现在右边的 M 表示该文件被修改了但是还没放入暂存区,出现在靠左边的 M 表示该文件被修改了并放入了暂存区。

本文转自  红尘世间  51CTO博客,原文链接:http://blog.51cto.com/hongchen99/1975553