我正在源代码中的回归工作。我想告诉Git:“根据参数化的日期/时间签出源代码”。这可能吗?
我目前的观点也有阶段性的变化,我不想失去这些变化。理想情况下,我希望在当前源文件和基于之前日期的某个我感兴趣的版本之间来回切换。
我正在源代码中的回归工作。我想告诉Git:“根据参数化的日期/时间签出源代码”。这可能吗?
我目前的观点也有阶段性的变化,我不想失去这些变化。理想情况下,我希望在当前源文件和基于之前日期的某个我感兴趣的版本之间来回切换。
当前回答
看起来你需要这样的东西: 基于日期的Git签出
换句话说,您使用rev-list来查找提交,然后使用签出 真正理解它。
如果您不想丢失阶段性更改,最简单的方法就是这样做 创建一个新分支,并将它们提交给该分支。你可以随时换回去 在树枝间来回。
编辑:链接断开了,下面是命令:
git checkout `git rev-list -n 1 --before="2009-07-27 13:37" master`
其他回答
进一步使用rev-list选项,如果你想找到最近的合并提交从你的主分支到你的生产分支(作为一个纯粹的假设的例子):
git checkout `git rev-list -n 1 --merges --first-parent --before="2012-01-01" production`
我需要找到特定日期的生产服务器上的代码。这为我找到了它。
安迪的解决办法对我没用。在这里,我找到了另一种方法:
git checkout `git rev-list -n 1 --before="2009-07-27 13:37" master`
Git:按日期结帐
保持当前的更改
你可以把你的工作藏起来,不用承诺,git stash。你 也不会用少管所的赃物把它拿回来。或者你也可以(如carleeto所说)git将它提交到一个单独的分支。
使用rev-parse按日期签出
你可以使用rev-parse在特定日期签出一个提交,就像这样:
git checkout 'master@{1979-02-26 18:30:00}'
关于可用选项的更多细节可以在git-rev-parse中找到。
正如评论中提到的,这个方法使用reflog来查找历史记录中的提交。默认情况下,这些条目在90天后过期。虽然使用reflog的语法没有那么冗长,但只能回溯到90天前。
使用rev-list按日期退房
另一个不使用reflog的选项是使用rev-list来获得在特定时间点的提交:
git checkout `git rev-list -n 1 --first-parent --before="2009-07-27 13:37" master`
如果你只想要你的历史记录而不是合并带来的版本,请注意——first-parent。这就是你通常想要的。
提醒,自Git 2.23(2019年8月)起
切换到一个新的分支从过去的提交日期: git switch -c newBranch $(git rev-list -n1——before=yyyy-mm-dd main) 还原当前工作树中过去某个日期的文件 git restore -SW -s $(git rev-list -n1——before=yyyy-mm-dd main)——path/to/file
在2021/2022年不要使用旧的、过时的、令人困惑的git checkout命令:git switch和git restore详细描述了它们正在做什么(只使用git switch的分支,只使用git restore的文件)
不要使用' ':更喜欢更现代的$(命令替换)语法,而不是过时的反撇号语法。
要从签出创建一个新分支,使用-b选项和新分支名称。
git checkout -b 19July2021 `git rev-list -n1 --before=2021-7-19 master`
当你处于“分离HEAD”状态时,你可以避免git切换