很多时候,对于一个大的文件,可能有的同学改完之后不想一次提交,想分批提交。但这个时候由于git add的机制往往add之后就是整个一个文件被放到stage区了,这个时候肯定会想能不能对一个文件可以进行分开的快区域提交概念呢?

答案其实是有的,就是

git add -p [filename]

filename为可选操作,如果不指定,git就会对所有的unstage文件进行一次遍历。

那么如何使用呢?

比如我们一个文件a.txt的内容如下

hello
world

此时我将a.txt的内容改成了

hello

此时运行git diff可以看到如下

+
hello
-world
+

这个时候问题来了,我想先提交”把2222222增加“的提交,然后再提交”删除world,然后再”增加1111111新行“的提交怎么做呢?

首先进行命令

git add -p

它会提示你输入什么命令,有

State this hunk? [y,n,q,a,d,/,s,e,?]?

具体的命令同学可以自己去查,在这里我们输入'e'进入手动选择模式

出现了如下内容

# Manual hunk edit mode -- see bottom for a quick guide
@@ -, +, @@
+
hello
-world
+
# ---
# To remove '-' lines, make them ' ' lines (context).
# To remove '+' lines, delete them.
# Lines starting with # will be removed.
#
# If the patch applies cleanly, the edited hunk will immediately be
# marked for staging. If it does not apply cleanly, you will be given
# an opportunity to edit again. If all lines of the hunk are removed,
# then the edit is aborted and the hunk is left unchanged.

终于到了这一步,好了,英文好的同学可以看提示操作,不会的你只要知道我总结的两条原则就行

 对于增加的内容(+),如果你在这个提交中不想放进去,就把整行删除
对于减去的内容(-),如果你在这个提交中不想删除,就把前面的‘-’删除,替换为一个空格

那么,按照我们之前的逻辑就应该改成这样

@@ -, +, @@
hello
world
+

这个时候wq,此时你输入

git diff --cached

就会和stage区的文件进行diff对比,你可以看到只是简单的22222被加进去了,

这个时候你commit,就完成了仅仅针对增加22222222的补丁形式的提交。

那么接下来就很简单了,按照之前的逻辑进入到git add -p中的e手动模式,变成如下格式即可完成这次的所有需求

原来的是这样

@@ -, +, @@
+
hello
-world

改成这样

@@ -, +, @@
hello
-world

那么,这次的提交就没有包括1111111的增加,只是简单的对world进行删除,最后commit即完成了world的删除,但是此时的1111111还没有加进去。

最后一个提交“111111111111加进去”其实已经很简单了,也不需要再用到git add -p了,只需简单的add和commit,即分别完成了对一个文件所做的三次提交。

参考链接: http://stackoverflow.com/questions/10731269/git-hunk-edit-mode-how-to-remove-a-line

Git对于单个文件的分批提交方式的使用的更多相关文章

  1. 【转载】Git设置单个文件上传大小

    git单个文件默认大小是50M,超过50M,会给出warning.大于100M会无法提交: 可以通过命令,修改单个文件默认大小(以设置500M以例): git config --global http ...

  2. git 恢复单个文件的历史版本

    首先查看该文件的历史版本信息:git log Default@2x.png 记录下需要恢复的commit版本号:如 9aa51d89799716aa68cff3f30c26f8815408e926 恢 ...

  3. git 恢复单个文件

    首先查看该文件的历史版本信息:git log Default@2x.png 记录下需要恢复的commit版本号:如 9aa51d89799716aa68cff3f30c26f8815408e926 恢 ...

  4. Git 合并单个文件

    有两个分支 # git branch -a * branchA branchB remotes/origin/branchC A分支合并B分支单个文件 注意是本地分支,还是远程分支 # git che ...

  5. git回退单个文件

    git原理 Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD. gi ...

  6. git批量删除文件和批量提交

    1. 单个删除文件: ① 通常直接在文件管理器中把没用的文件删了,或者用rm命令删了:(可选操作,可直接执行②删除) $ rm test.txt ② 确实要从版本库中删除该文件,那就用命令git rm ...

  7. GIT 恢复单个文件到历史版本

    首先查看该文件的历史版本信息:git log <file> 恢复该文件到某个历史版本:git reset 版本号 <file> 检出改文件到工作区:git checkout - ...

  8. 【Git版本控制】git将单个文件回退到某一版本

    暂定此文件为a.jsp 1.进入到a.jsp所在目录,通过 git  log a.jsp查看a.jsp的更改记录 2.找到想要回退的版本号:例如 fcd2093 通过 git reset   fcd2 ...

  9. Git查看单个文件修改历史

    1 命令 git log --pretty=oneline  文件名 ➜ admin git:(feature/v1.5.0_20181202_group) git log --pretty=onel ...

随机推荐

  1. 「Poetize4」玉蟾宫

    描述 Description 这片土地被分成N*M个格子,每个格子里写着'R'或者'F',R代表这块土地被赐予了rainbow,F代表这块土地被赐予了freda.现在freda要在这里卖萌...它要找 ...

  2. awk合并文件一例

    群里的朋友求助: $ cat file1a 1 2 3b 2 3 4c 3 4 5 $ cat file2d 你b 好c 吗 合并两个文件,需要实现: a 1 2 3b 2 3 4 好c 3 4 5 ...

  3. 图论(网络流):[SCOI2015]小凸玩矩阵

    Description 小凸和小方是好朋友,小方给小凸一个N*M(N<=M)的矩阵A,要求小秃从其中选出N个数,其中任意两个数字不能在同一行或同一列,现小凸想知道选出来的N个数中第K大的数字的最 ...

  4. Unique Paths II ——LeetCode

    Follow up for "Unique Paths": Now consider if some obstacles are added to the grids. How m ...

  5. Happy Number——LeetCode

    Write an algorithm to determine if a number is "happy". A happy number is a number defined ...

  6. UVa 11178计算几何 模板题

    #include<cstdio> #include<cstring> #include<cmath> #include<iostream> #inclu ...

  7. OpenWrt简要刷机教程

    准备工作 1. 下载openwrt中文固件到PC.(当然其他英文固件也可) 2  找到路由器的RST键. 3  找到路由器刷机口---姑且称之为“WAN口” 4. 关闭路由器的电源. 5. 将PC网口 ...

  8. android 客户端 和 新浪微博如何打通的

    微博SDK 为开发者 提供访问oauth2.0 授权认证,并集合sso登录功能,使用第三方应用可通过 新浪微博的 登录操作 提供微博分享功能,可直接通过微博客户端分享微博 名词解释 AppKey 分配 ...

  9. Bash 字符串处理命令

    字符串长度 str="abc" echo ${#str} 查找子串的位置 str="abc" str1=`expr index $str "a&quo ...

  10. [转]机器学习&数据挖掘笔记_16(常见面试之机器学习算法思想简单梳理)

    机器学习&数据挖掘笔记_16(常见面试之机器学习算法思想简单梳理) 转自http://www.cnblogs.com/tornadomeet/p/3395593.html 前言: 找工作时(I ...