我在过去的某个时候删除了一个文件或文件中的一些代码。我可以在内容中(而不是在提交信息中)进行grep吗?
一个非常糟糕的解决方案是在日志中进行grep。
git log -p | grep <pattern>
然而,这并不能直接返回提交哈希值。我用git grep
玩了一下,但没有效果。
要搜索提交的*内容(即实际的源代码行,而不是提交信息之类的),你需要做的是。
git grep <regexp> $(git rev-list --all)
git rev-list --all | xargs git grep <expression>
在遇到"参数列表太长"的错误时,会起作用。
如果你想把搜索限制在某个子树上(例如,"lib/util"),你需要把它传给rev-list
子命令和grep
。
git grep <regexp> $(git rev-list --all -- lib/util) -- lib/util
这将在你所有的提交文本中搜索 "regexp"。
之所以在两个命令中都传递路径,是因为rev-list
将返回所有发生在lib/util
上的修改列表,但同时你也需要传递给grep
,使它只搜索lib/util
。
想象一下下面的情况:grep
可能会在rev-list
返回的同一版本中包含的其他文件上找到相同的<regexp>
(即使在该版本中没有对该文件进行修改)。
这里有一些搜索源代码的其他有用方法。
搜索工作树中与正则表达式regexp匹配的文本。
git grep <regexp>
搜索工作树中符合正则表达式regexp1或regexp2的文本行。
git grep -e <regexp1> [--or] -e <regexp2>
搜索工作树中符合正则表达式regexp1和regexp2的文本行,仅报告文件路径。
git grep -e <regexp1> --and -e <regexp2>
搜索工作树中与正则表达式regexp1匹配的文本行和与正则表达式regexp2匹配的文本行的文件。
git grep -l --all-match -e <regexp1> -e <regexp2>
搜索工作树中与正则表达式匹配的已更改的文本行。
git diff --unified=0 | grep <pattern>
搜索所有修订版中与正则表达式regexp匹配的文本。
git grep <regexp> $(git rev-list --all)
搜索rev1和rev2之间的所有修订,寻找与正则表达式regexp匹配的文本。
git grep <regexp> $(git rev-list <rev1>..<rev2>)
来搜索 Foo
。
git log -SFoo -- path_containing_change
git log -SFoo --since=2009.1.1 --until=2010.1.1 -- path_containing_change
更多信息请参见 Git history - find lost line by keyword 。
正如Jakub Narębski所评论的。
这个寻找引入或删除<string>
的实例的差异。
这通常意味着"你添加或删除了带有'Foo'的行的修订案"。
the --pickaxe-regex
选项允许你使用扩展的POSIX regex,而不是搜索一个字符串。
我最喜欢的方法是使用git log
'的G
选项(1.7.4版本中添加)。
-G<regex>
Look for differences whose added or removed line matches the given <regex>.
-G
和-S
选项决定提交是否匹配的方式有细微差别。
-S
选项主要是计算提交前和提交后文件中搜索匹配的次数。
如果前后的次数不同,则会在日志中显示提交。
例如,这不会显示与你的搜索匹配的行被移动的提交。以这个提交为例。
diff --git a/test b/test
index dddc242..60a8ba6 100644
--- a/test
+++ b/test
@@ -1 +1 @@
-hello hello
+hello goodbye hello
因为文件中出现的"hello" 在文件中出现的次数在这次提交前后是一样的,所以不会用 "hello "来匹配。 但是,由于有一行与 "hello "相匹配的修改,所以会用 "Ghello "来显示提交。
我采用了 [@Jeet'的答案][1],并将其移植到 Windows 中(感谢 [这个答案][2])。
FOR /F %x IN ('"git rev-list --all"') DO @git grep <regex> %x > out.txt
请注意,对我来说,由于某些原因,删除这个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
是在所有分支中搜索文本的一种更有效的方法,尤其是当有许多匹配的文本,并且你想先看到最近(相关)的变化时。
git log -p --all -S 'search string'
git log -p --all -G 'match regular expression'
这些日志命令列出了添加或删除给定的搜索字符串/regex的提交,(一般来说)是最近的提交。
-p
选项会显示相关的差异,所以你可以在上下文中看到它。
找到了相关的提交,并添加了你要找的文本 (例如:8beeff00d)。 8beeff00d),找到包含该提交的分支。
git branch -a --contains 8beeff00d
在任何版本、任何文件中搜索。
git rev-list --all | xargs git grep <regexp>
只在某些给定的文件中搜索,例如**XML文件。
git rev-list --all | xargs -I{} git grep <regexp> {} -- "*.xml"
结果行应该是这样的。 6988bec26b1503d45eb0b2e8a4364afb87dde7af:bla.xml: 找到的行的文本...
然后你可以用git show
获得更多信息,比如作者、日期、差异。
git show 6988bec26b1503d45eb0b2e8a4364afb87dde7af
为了简单起见,我'建议使用GUI。 gitk - Git 仓库浏览器](https://git-scm.com/docs/gitk)。 它非常灵活
搜索文件。
[![在此输入图像描述][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 grep -n <regex> $(git rev-list --all)
下面显示了所有提交中包含 "密码 "的文件。
# store intermediate result
$result = git grep -n "password" $(git rev-list --all)
# display unique file names
$result | select -unique { $_ -replace "(^.*?:)|(:.*)", "" }
那么,你是否试图通过旧版本的代码来寻找最后存在的东西?
如果我在做这个,我可能会使用git bisect。 使用bisect,你可以指定一个已知的好版本,一个已知的坏版本,以及一个简单的脚本,来检查这个版本是好是坏(在这个例子中,用grep来检查你要找的代码是否存在)。 运行这个脚本就可以找到该代码是什么时候被删除的。
场景。 你用IDE对你的代码进行了一次大清理。 问题是:IDE清理了更多的代码,现在你的代码无法编译(缺少资源等)。 IDE清理了更多的代码,现在你的代码无法编译(缺少资源等)。
解决方法: {{{7010732}}你用IDE做了一次大的清理,现在你的代码不能编译(缺少资源等)。
git grep --cached "text_to_find"
它将找到"text_to_find".被修改的文件。 被修改的文件。
现在你可以撤消这个修改,然后编译你的代码。
每当我发现自己在你那里的时候,我都会使用以下命令行。
git log -S "<words/phrases i am trying to find>" --all --oneline --graph
解释。
-S "<单词/短语,我正在努力寻找>"
-它显示了所有Git提交的文件(添加/修改/删除)中有我正在努力寻找的单词/短语,没有'<>'
符号。
--all
--要在所有分支中执行和搜索。
--oneline
--它将Git日志压缩在一行。
--graph
--创建按时间顺序排列的提交图。