- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对一个函数进行了多项更改,并使用 git add -p
暂存了其中一项。在提交它之前,我想检查一下这个更改是否确实做了它应该做的事情。
因此我想完全按照暂存区中的原样打印代码,以便我可以复制此函数并在单独的文件中对其进行测试。
在 gitk
中会有这个有用的单选按钮,我可以在其中选择 New version 而不是 Diff。但是,我不能在这里使用 gitk,因为我是通过 ssh 连接到没有图形用户界面的计算机。
如果更改已经提交,我可以使用 git show HEAD:myfile
(尽管这会打印整个文件,这远远超出了我目前感兴趣的范围)但我不知道如何指定暂存区域而不是 HEAD。
我对两者都感兴趣:
git show
中指定暂存区域以便打印整个文件?我找到了 this answer但是 -e
没有记录在 git diff --help
中,当尝试使用它时我得到 error: invalid option: -e.
当然我可以提交更改,在 git show HEAD:myfile
的输出中搜索它们,然后在必要时使用 git commit --amend
更改提交,但是我觉得一定有更简单的方法。
最佳答案
称为暂存区 的东西也称为索引。因此文件的暂存副本也是文件的索引副本。要引用特定文件的索引副本,请使用前导冒号语法::<em>digit</em>:<em>filename</em>
,例如 :0:myfile
:
git show :0:myfile
索引在暂存槽 0 中保存文件的 1 个副本,或在暂存槽 1、2 和 3 中保存(最多)三个文件副本。后者仅在 merge 期间发生,同时解决冲突.由于您不在冲突 merge 的中间,因此您的文件仅存在于第零阶段。您可以省略数字和第二个冒号来表示“暂存槽零”:
git show :myfile
(比较 git show HEAD:myfile
,它从 HEAD
提交中提取文件的副本,或 git show <em>hash</em>:myfile
,它从给定的提交哈希中提取文件的副本。所有这些都在内部工作,文件的 Git 化副本,采用特殊的 Git-only、提交文件只读格式——已复制到索引中的文件已经采用这种形式。)
diff HEAD
针对索引提交,使用:
git diff --cached
请注意,这会比较 HEAD
中的每个 文件针对索引中的每个 文件。索引中的大多数文件已经与 HEAD
中的副本匹配, 当然。特别是,如果您这样做了:
git checkout master
<edit some file>
git add [options] just-one-file
然后每个文件除了 just-one-file
索引/暂存区中的文件与 HEAD
中的对应文件匹配, 因此 diff 将只显示一个文件。
如果索引中有多个文件与其 HEAD
不同同行,可以限制git diff
使用路径名进一步输出:
git diff --cached -- myfile
例如。 (这仍将显示所有已删除的行。)
(有一个常见的误解,认为暂存区仅包含新 文件。事实并非如此——它实际上包含每个 文件,准备提交,根本次 — 但由于许多教程中描述暂存区域的方式以及 git diff
没有向您显示未更改文件的任何内容,它可能看起来 一开始就是这样。要查看暂存区中所有文件的列表以及有关它们的信息,请使用 git ls-files --stage
。请注意,此列表可能很长!)
关于git - 排除 git diff 中删除的行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57025220/
我在我们的系统中使用了多种不同的查询,我们想要获取分页的“总”记录。 我所遵循的所有地方都遵循这种结构 - var query1 = "select SQL_CALC_FOUND_ROWS ...."
我是 diff 的新手。我过去用过它。但我想知道,是否可以使用 diff 来跟踪希伯来语中两个文件之间的差异?我想比较具有元音点和重音符号的圣经希伯来文文件。 最佳答案 我不知道有任何“差异”(文件比
在Word中,有一个选项可以比较两个文档并找出两个文档之间的差异。我正在寻找一个类似的功能来比较两个Powerpoint文档。理想情况下,它将列出不同的单个幻灯片,每个幻灯片之间版本之间的差异以及进行
Bizzaro-Diff!!! 有没有办法做一个只显示一组文件中相同部分的 bizzaro/inverse-diff? (即远超过 three files ) 奇怪的问题,我知道...但我正在将某人的
我将 git 与默认的 Ubuntu 12.04 软件包一起使用: git --version git version 1.7.9.5 我找不到任何可以让 git diff 打开外部差异工具的机制,它
这是我的树 ├── test │ ├── dir1 │ └── dir2 │ ├── file │ └── file2 └── test2 └── dir2
我在 source forge ( cocoa.diff ) 上找到了这个补丁,这意味着我可以使用 cocoa.diff 文件进行补丁。但是,我似乎无法弄清楚如何使用 .diff 文件。 谢谢你的帮助
我修改了某个文件的第 494 行,并使用 cvs diff -u4 来查看我修改的内容,cvs 输出如下内容: @@ -490,9 +490,9 @@ if (!(hPtr->hSta
我需要知道这两个补丁是否有效相同。 我有一个旧补丁文件和使用 unix diff 命令创建的新补丁文件。由于补丁创建时的时间戳,只是比较补丁会报告差异。 有没有办法(有差异?)可以可靠地告诉我这两个补
我有这样的东西 src/sim/simulate.cc 41d40 public: > 61,62c60,61 a.patch 用于创建补丁文件,尽管也可能会抛出一些其他开关(-N?)
我想知道是否有工具可以显示与 debian 打包相关的补丁中使用的 *.diff 文件。我需要从该工具中获得的是它可以只读取 diff 文件并显示随更改的行更改的实际文件,就像 kdiff 或 mel
主要有3个git diff版本: git diff - difference between WORKING DIRECTORY & STAGE git diff --staged - differe
根据 Ender 的 Applied Econometric Time Series ,变量 y 的二阶差分定义为: Pandas 提供了 diff 函数,它接收“periods”作为参数。尽管如此,
这是我的差异的开始部分。 #!/usr/bin/env python import fileinput import difflib import subprocess import sys # fo
有没有办法在 svn diff 或任何其他工具(基于 linux)到 仅显示空格/制表符更改 ?. 目的,我不希望 checkin 这些差异。如果工具可以捕获这些差异,我可以在 checkin 之前将
我正在尝试比较忽略回车符的文件 - diff -b 在任何其他 unix 上的表现令人钦佩。但是在这个 AIX 5.3 机器上: tst1:tst2$ od -c testfile 00000
这个问题已经有答案了: What does the “@@…@@” meta line with at signs in svn diff or git diff mean? (3 个回答) 已关闭
我在使用 git diff --word-diff 时遇到了问题。问题是当 diff 获取没有换行符的文件(单行文件)时,它会逐行区分。我想逐字区分。 以下是当我在没有换行符的情况下比较文件时发生的情
这个问题在这里已经有了答案: Highlight changed lines and changed bytes in each changed line (12 个答案) 关闭 7 年前。 给定一
我正在尝试使用两个大文件夹(〜7GB)创建一个补丁。 这是我的做法: $ diff -Naurbw . ../other-folder > file.patch 但可能由于文件大小而导致未创建补丁并给
我是一名优秀的程序员,十分优秀!