Git 2 - Git Basics

1 add

  • github 上建立新的 repository,命名 demo
  • git clone 到本地 github 目录
  • 将自己之前的项目 copy 到该 demo 目录下
  • 运行 cat .gitignore

注意: .gitignore的目录并不一定要是根目录,比如在 try 文件夹下建立一个 .gitignore 来设置 try 文件夹中的忽略文件:$ cat try/.gitignore 即可。其 ignore 的内容为

rd.txt
/rd/

如果此前这些文件已经被 track ,则使用 git rm --cached 删除 staged 区的对应文件。

  • git add .
  • git status 查看,除去被 ignore 的文件,其他文件都是 staged 状态,说明 gitignore 生效
  • 修改其中一个被跟踪的文件 readme.md,再查看,则之后修改的文件状态为 modified (changes not staged for commit)

注意:add 的意思是 add this content to the next commit(即 add 后会进入 staged 状态)

2 commit

  • 将 git add .,之后git commit -m "inital"
  • git status,此时nothing to commit, working directory clean
  • 之后 push 之前再 commit 就需要使用 git commit --amend.可以修改提交说明,修改后,按Esc进入命令行,:,wq或wq!(强制执行)。之后可以查看本次的 commit 信息:master 分支, ccced2c 是 SHA-1 校验和。
$ git commit --amend
[master ccced2c] first commit
158 files changed, 17500 insertions(+)
create mode 100644 .classpath
create mode 100644 .gitignore
  • 直接 commit ,无需 add 。使用$git commit -a -m 'added'

3 查看修改

  • git diff (查看 working directory 与 staged 区的不同)
  • $git diff --staged(查看 staged 区与 commit 区的不同)

4 删除文件(指从 staging 区删除,也就是不再 track)

  • 工作区和 staging 区都删除
xueyuan@EF-XUEYUAN /D/github/demo (master)
$ git rm try.md
rm 'try.md' xueyuan@EF-XUEYUAN /D/github/demo (master)
$ git diff xueyuan@EF-XUEYUAN /D/github/demo (master)
$ git diff --staged
diff --git a/try.md b/try.md
deleted file mode 100644
index e69de29..0000000
  • 只 staging 区删除,工作区不删除(忽略 gitignore 时经常使用)
xueyuan@EF-XUEYUAN /D/github/demo (master)
$ git rm --cached try.md
rm 'try.md' xueyuan@EF-XUEYUAN /D/github/demo (master)
$ git diff xueyuan@EF-XUEYUAN /D/github/demo (master)
$ git diff --staged
diff --git a/try.md b/try.md
deleted file mode 100644
index e69de29..0000000

注意:$git rm log/\*.log 中的“\”

5 重命名

$git mv file_from file_to

6 查看 commit 历史

$git log 所有历史

$git log -p -2 最后两此提交作比较

$git log --stat 查看每次提交的简略统计数据(修改文件数,修改行数)

限制输出数量如:

$git log --since=2.weeks

其他如下:

xueyuan@EF-XUEYUAN /D/github/demo (master)
$ git log --pretty=oneline
c38bac265c1337835cad91f9bf0cb2d2aa91a103 second commit
62ff73d37c185377cf1911a3e5fe2f58225f0136 first commit xueyuan@EF-XUEYUAN /D/github/demo (master)
$ git log --pretty=format:"%h - %an, %ar : %s"
c38bac2 - xueyuan, 9 minutes ago : second commit
62ff73d - xueyuan, 3 hours ago : first commit xueyuan@EF-XUEYUAN /D/github/demo (master)
$ git log --pretty=format:"%h %s"--graph
c38bac2 second commit--graph
62ff73d first commit--graph

7 撤销操作

(1)重提交

$git commit --amend

$git commit -m 'initial commit'
$git add forgotten_file
$git commit --amend

这样第二次提交取代第一次,一共只有一次提交

(2)Unstaging a Staged File

$git reset HEAD CONTRIBUTING.md

$git add .
$git status
On branch master
Changes to be committed:
(use "git reset HEAD <file>..." to unstage)
renamed: README.md -> README
modified: CONTRIBUTING.md
$git reset HEAD CONTRIBUTING.md
Unstaged changes after reset:
M CONTRIBUTING.md
$git status
On branch master
Changes to be committed:
(use "git reset HEAD <file>..." to unstage)
renamed: README.md -> README
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: CONTRIBUTING.md

(3)Unmodifying a Modified File

恢复到last committed (or initially cloned, or however you got it into your working directory)

$git checkout -- CONTRIBUTING.md

$git checkout -- CONTRIBUTING.md
$git status
On branch master
Changes to be committed:
(use "git reset HEAD <file>..." to unstage)
renamed: README.md -> READMEc

注意:所有(包括被删除的分支,和--amend的提交)被 commit 到 Git 的都可以被恢复。

8 远程仓库

  • 查看远程仓库:$git remote -v
  • 添加远程仓库:$git remote add pb https://github.com/paulboone/ticgit
  • 抓取本地库没有的信息:
    • $git fetch pb(需手动合并)
    • $git pull pb(自动合并到当前分支,常用)
  • 推送数据到远程仓库:$git push [remote名] [branch名]

    注意:如果 push 前有他人已经推送了更新,则你的推送会被驳回。此时必须先把他人的更新抓取到本地,并入自己的项目,再推送。
  • 查看远程仓库信息:$git remote show [remote-name]
  • 删除远程仓库:$git remote rm [remote-name]
  • 重命名远程仓库:$git remote rename [old] [new]

pro git 读书笔记 2的更多相关文章

  1. Pro Git 读书笔记

    一. 起步 1. 集中式版本控制缺点:中央服务器的单点故障. 分布式版本控制优点:客户端并不只提取最新版本的文件快照,而是把代码仓库完整地镜像下来. 这么一来,任何一处协同工作用的服务器发生故障,事后 ...

  2. Pro Git读书笔记 - 分支

    Git 分支介绍. 几乎所有的版本控制系统都以某种形式支持分支. 使用分支意味着你可以把你的工作从开发主线上分离开来,以免影响开发主线. 在很多版本控制系统中,这是一个略微低效的过程--常常需要完全创 ...

  3. Pro Git读书笔记 - Git 常用命令

    在工作目录中初始化新仓库 要对现有的某个项目开始用 Git 管理,只需到此项目所在的目录,执行git init 检查当前文件状态 要查看哪些文件处于什么状态,可以用git status命令 将工作文件 ...

  4. pro git 读书笔记 3 Git 分支

    分支 新建分支:git branch 分支名 切换到该分支:git checkout 分支名 补充:以上两条语句等价于一句:git checkout -b 分支名 转换分支的时候最好保持一个清洁的工作 ...

  5. pro git 读书笔记 1

    Git 1 - Getting Started Git 的特点 Git 存储每个版本的快照:其他 VCS(版本控制系统) 存储两个版本的变化之处 好处参考 Git 分支章节 Git 几乎所有操作都是本 ...

  6. 《Pro Git》笔记3:分支基本操作

    <Pro Git>笔记3:Git分支基本操作 分支使多线开发和合并非常容易.Git的分支就是一个指向提交对象的可变指针,极其轻量.Git的默认分支为master. 1.Git数据存储结构和 ...

  7. Pro Git 学习笔记

    Pro Git 学习笔记 文档地址:Pro Git原文地址:PRO GIT 学习笔记 git常见命令 1.Git起步 初次运行Git前的配置 用户信息 git config --global user ...

  8. 《Pro Git》笔记2:Git基础操作

    第二章 Git基础 Git基础包括:版本库的创建和获取,文件添加修改提交等基本操作,状态查询,远程版本库管理和同步,打标签. 1.取得项目的Git版本库 基于Git的工作流要以Git版本库为基础,即可 ...

  9. 《Pro Git》笔记1:起步

    第一章 起步 1.关于版本控制 版本控制用于记录和追踪目录结构和文件内容变化,能够追溯过去的任何修改和变化,并恢复到任何历史状态. 版本控制系统可以按照发展过程分成以下几类: 目录备份.记录版本变化最 ...

随机推荐

  1. redis 持久化之 RDB & AOF

    Redis 持久化实现方式 快照对数据某一时间点的完整备份.例如Linux 快照备份.Redis RDB.MySQL Dump. 日志将数据的所有操作都记录到日志中,需要恢复时,将日志重新执行一次.M ...

  2. 【LOJ】#3086. 「GXOI / GZOI2019」逼死强迫症

    LOJ#3086. 「GXOI / GZOI2019」逼死强迫症 这个就是设状态为\(S,j\)表示轮廓线为\(S\),然后用的1×1个数为j 列出矩阵转移 这样会算重两个边相邻的,只要算出斐波那契数 ...

  3. [Err] 1054 - Unknown error 1054

    [Err] 1054 - Unknown error 1054:很小的一个错误,缺耽误很长的时间,字段不匹配: 解决方法:一一对照字段,数据库字段要和类中的字段要对应,或者sql语句中使用的字段!仔细 ...

  4. T100——取得系统参数值,如关帐日期

    CALL cl_get_para(g_enterprise,g_site,'S-MFG-0031') RETURNING l_para_data 用此方法获取关帐日期

  5. pb datawindow的用法

    1. 使DataWindow列只能追加不能修改如何使DataWindow中的数据只能追加新记录而不能修改,利用 Column 的 Protect 属性可以很方便的做到这一点,方法如下:将每一列的 Pr ...

  6. FTP-实例(Md5验证)

    import socket, os, hashlib server = socket.socket() server.bind(("localhost", 9999)) serve ...

  7. Web 开发和数据科学家仍是 Python 开发的两大主力

    由于 Python 2 即将退役,使用 Python 3 的开发者大约为 90%,Python 2 的使用量正在迅速减少.而去年仍有 1/4 的人使用 Python 2. Web 开发和数据科学家仍是 ...

  8. c# TCP/IP协议利用Socket Client通信(只含客户端Demo)

    完全是基础,新手可以随意看看,大牛可以关闭浏览页了,哈哈. TCP/IP协议 TCP/IP是一系列网络通信协议的统称,其中最核心的两个协议是TCP和IP.TCP称为传输控制协议,IP称为互联网络协议. ...

  9. JS基础_自增自减练习

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  10. kbmMW均衡负载与容灾(1)

    kbmMW为均衡负载与容灾提供了很好的机制,支持多种实现方式,现在看看最简单的一种,客户端控制的容灾和简单的负载均衡. 现在,我们将kbmMWServer部署到不同的服务器,或者在同一服务器部署多份实 ...