如何在Git历史中grep(搜索)已提交的代码
我在过去的某个时候删除了一个文件或文件中的一些代码。我可以在内容中(而不是在提交信息中)进行grep吗?
一个非常糟糕的解决方案是在日志中进行grep。
git log -p | grep <pattern>
然而,这并不能直接返回提交哈希值。我用git grep
玩了一下,但没有效果。
1338
15
我在过去的某个时候删除了一个文件或文件中的一些代码。我可以在内容中(而不是在提交信息中)进行grep吗?
一个非常糟糕的解决方案是在日志中进行grep。
git log -p | grep <pattern>
然而,这并不能直接返回提交哈希值。我用git grep
玩了一下,但没有效果。
要搜索提交的*内容(即实际的源代码行,而不是提交信息之类的),你需要做的是。
git rev-list --all | xargs git grep
在遇到"参数列表太长"的错误时,会起作用。如果你想把搜索限制在某个子树上(例如,"lib/util"),你需要把它传给
rev-list
子命令和grep
。这将在你所有的提交文本中搜索 "regexp"。
之所以在两个命令中都传递路径,是因为
rev-list
将返回所有发生在lib/util
上的修改列表,但同时你也需要传递给grep
,使它只搜索lib/util
。想象一下下面的情况:
grep
可能会在rev-list
返回的同一版本中包含的其他文件上找到相同的``(即使在该版本中没有对该文件进行修改)。这里有一些搜索源代码的其他有用方法。
搜索工作树中与正则表达式regexp匹配的文本。
搜索工作树中符合正则表达式regexp1或regexp2的文本行。
搜索工作树中符合正则表达式regexp1和regexp2的文本行,仅报告文件路径。
搜索工作树中与正则表达式regexp1匹配的文本行和与正则表达式regexp2匹配的文本行的文件。
搜索工作树中与正则表达式匹配的已更改的文本行。
搜索所有修订版中与正则表达式regexp匹配的文本。
搜索rev1和rev2之间的所有修订,寻找与正则表达式regexp匹配的文本。
你应该使用
git log
的镐(-S
)选项。来搜索
Foo
。更多信息请参见 Git history - find lost line by keyword 。
正如Jakub Narębski所评论的。
这个寻找引入或删除``的实例的差异。
这通常意味着"你添加或删除了带有'Foo'的行的修订案"。
the
--pickaxe-regex
选项允许你使用扩展的POSIX regex,而不是搜索一个字符串。正如Rob所评论的,这种搜索是区分大小写的--他开了一个后续问题关于如何搜索不区分大小写。
我最喜欢的方法是使用
git log
'的G
选项(1.7.4版本中添加)。-G
和-S
选项决定提交是否匹配的方式有细微差别。-S
选项主要是计算提交前和提交后文件中搜索匹配的次数。 如果前后的次数不同,则会在日志中显示提交。 例如,这不会显示与你的搜索匹配的行被移动的提交。以这个提交为例。
因为文件中出现的"hello" 在文件中出现的次数在这次提交前后是一样的,所以不会用 "hello "来匹配。 但是,由于有一行与 "hello "相匹配的修改,所以会用 "Ghello "来显示提交。
如果你想浏览代码的变化(查看整个历史中给定的词实际被修改了什么),请使用 "补丁 "模式--我发现一个非常有用的组合。
我采用了 [@Jeet'的答案][1],并将其移植到 Windows 中(感谢 [这个答案][2])。
请注意,对我来说,由于某些原因,删除这个regex的实际提交并没有出现在命令的输出中,而是在它之前的一次提交中。
[1]: https://stackoverflow.com/questions/2928584/how-to-grep-in-the-git-history/2929502#2929502 [2]: https://stackoverflow.com/questions/434038/whats-the-cmd-powershell-equivalent-of-back-tick-on-bash/434087#434087
git log
是在所有分支中搜索文本的一种更有效的方法,尤其是当有许多匹配的文本,并且你想先看到最近(相关)的变化时。这些日志命令列出了添加或删除给定的搜索字符串/regex的提交,(一般来说)是最近的提交。
-p
选项会显示相关的差异,所以你可以在上下文中看到它。找到了相关的提交,并添加了你要找的文本 (例如:8beeff00d)。 8beeff00d),找到包含该提交的分支。
在任何版本、任何文件中搜索。
只在某些给定的文件中搜索,例如**XML文件。
结果行应该是这样的。 6988bec26b1503d45eb0b2e8a4364afb87dde7af:bla.xml: 找到的行的文本...
然后你可以用
git show
获得更多信息,比如作者、日期、差异。为了简单起见,我'建议使用GUI。 gitk - Git 仓库浏览器](https://git-scm.com/docs/gitk)。 它非常灵活
[![在此输入图片描述][1]][1] 。
搜索文件。
[![在此输入图像描述][2]][2]。
当然,它也支持正则表达式。
<br/>。 [![在此输入图片描述][3]][3] 。
你可以使用上/下箭头浏览结果。
[1]: https://i.stack.imgur.com/3Ymk8.png [2]: https://i.stack.imgur.com/58qpA.png [3]: https://i.stack.imgur.com/U3tat.png
如果有人想在Sourcetree中做这件事,UI中没有直接的命令(从1.6.21.0版本开始)。 但是,你可以通过打开终端窗口(主工具栏上的按钮)并将其复制/粘贴到其中,来使用在接受的答案中指定的命令。
请注意。 Sourcetree'的搜索视图可以为你进行部分文本搜索。 按Ctrl
不支持RegEx。
@Jeet'的答案在PowerShell中有效。
下面显示了所有提交中包含 "密码 "的文件。
那么,你是否试图通过旧版本的代码来寻找最后存在的东西?
如果我在做这个,我可能会使用git bisect。 使用bisect,你可以指定一个已知的好版本,一个已知的坏版本,以及一个简单的脚本,来检查这个版本是好是坏(在这个例子中,用grep来检查你要找的代码是否存在)。 运行这个脚本就可以找到该代码是什么时候被删除的。
是对 @Jeet'解决方案的一个调整,所以它在搜索时显示结果,而不是仅仅在搜索结束时显示(在大型仓库中可能需要很长时间)。
场景。 你用IDE对你的代码进行了一次大清理。 问题是:IDE清理了更多的代码,现在你的代码无法编译(缺少资源等)。 IDE清理了更多的代码,现在你的代码无法编译(缺少资源等)。
解决方法: {{{7010732}}你用IDE做了一次大的清理,现在你的代码不能编译(缺少资源等)。
它将找到"text_to_find".被修改的文件。 被修改的文件。
现在你可以撤消这个修改,然后编译你的代码。
每当我发现自己在你那里的时候,我都会使用以下命令行。
解释。
-S "<单词/短语,我正在努力寻找>"
-它显示了所有Git提交的文件(添加/修改/删除)中有我正在努力寻找的单词/短语,没有'<>' 符号。--all
--要在所有分支中执行和搜索。--oneline
--它将Git日志压缩在一行。--graph
--创建按时间顺序排列的提交图。在我的例子中,我需要搜索一个短提交,但不幸的是,所列出的解决方案并不奏效。
我设法用以下方法来实现。 (替换REGEX标记)