我正在将所有内容转换为Git供我自己使用,我发现存储库中已经有一些旧版本的文件。我如何根据文件的“修改日期”以正确的顺序将其提交到历史记录中,以便我拥有文件的准确历史记录?

有人告诉我这样可行

git filter-branch --env-filter="GIT_AUTHOR_DATE=... --index-filter "git commit path/to/file --date " --tag-name-filter cat -- --all  

当前回答

你总是可以在你的计算机上更改日期,提交,然后更改日期并推送。

其他回答

你总是可以在你的计算机上更改日期,提交,然后更改日期并推送。

Pre-Step。

将所有数据从远程存储库拉到本地存储库。 我们正在使用——modify和——date开关。

具体命令如下:

$ git commit——modify——date="YYYY-MM-DD HH:MM:SS"

您可以像往常一样创建提交,但是在提交时,将环境变量GIT_AUTHOR_DATE和GIT_COMMITTER_DATE设置为适当的日期时间。

当然,这将使提交位于分支的顶端(即,在当前HEAD提交的前面)。如果你想在回购中把它推得更远,你必须变得有点花哨。假设你有这样的历史:

o--o--o--o--o

你希望你的新提交(标记为“X”)出现在第二:

o--X--o--o--o--o

最简单的方法是从第一次提交开始分支,添加新提交,然后在新提交的基础上重新构建所有其他提交。像这样:

$ git checkout -b new_commit $desired_parent_of_new_commit
$ git add new_file
$ GIT_AUTHOR_DATE='your date' GIT_COMMITTER_DATE='your date' git commit -m 'new (old) files'
$ git checkout master
$ git rebase new_commit
$ git branch -d new_commit

或者只是使用假git-history来为特定的数据范围生成它。

下面是我用来在过去N=1天提交对foo的更改:

git add foo
git commit -m "Update foo"
git commit --amend --date="$(date -v-1d)"

如果你想提交一个更早的日期,比如3天前,只需更改日期参数:date -v-3d。

例如,当你忘记昨天提交某件事情时,这真的很有用。

UPDATE:——date也接受像“3天前”这样的表达式,甚至是“昨天”这样的表达式。所以我们可以把它压缩成一行命令:

git add foo ; git commit --date "yesterday" -m "Update"