我克隆了某个项目的git存储库。我可以将文件转到初始状态吗?当我查看文件时,可以转到修订版2、3、4。。。最近?我想了解一下项目的发展情况。
当前回答
在执行此命令之前,请记住它将使您处于分离状态
使用gitcheckout<sha1>签出特定的提交。
其中<sha1>是可以通过gitlog获得的提交唯一编号
以下是处于分离头部状态后的一些选项:
复制文件或对git文件夹外的文件夹进行所需的更改,在需要时签出分支git checkout<existingBranch>并替换文件创建一个新的本地分支git checkout-b<new_branch_name><sha1>
其他回答
在执行此命令之前,请记住它将使您处于分离状态
使用gitcheckout<sha1>签出特定的提交。
其中<sha1>是可以通过gitlog获得的提交唯一编号
以下是处于分离头部状态后的一些选项:
复制文件或对git文件夹外的文件夹进行所需的更改,在需要时签出分支git checkout<existingBranch>并替换文件创建一个新的本地分支git checkout-b<new_branch_name><sha1>
要转到特定版本/提交,请运行以下命令。可以从git-log中获得的HASH-CODE--oneline-n10
git reset --hard HASH-CODE
注意-在重置为特定版本/提交后,如果您想恢复所有放弃的提交,可以运行git pull--rebase。
我遇到的情况是,我们有一个主分支,然后有一个名为17.0的分支,在这个17.0中有一个提交散列,不说“XYZ”。客户将获得XYZ版本之前的版本。现在我们遇到了一个bug,需要为该客户解决。因此,我们需要为该客户创建单独的分支,直到“xyz”散列。我是这样做的。
首先,我在本地计算机上创建了一个具有该客户名称的文件夹。客户名称为“AAA”创建该文件夹后,在此文件夹中发出以下命令:
初始化gitclone执行此命令后,您将进入主分支。所以切换到所需的分支git checkout 17.0这将把您带到提交的分支机构git checkout这将占用您的存储库直到哈希提交。查看我们的分支的名称,它被更改为提交哈希编号。现在给这个哈希指定一个分支名称gitbranch ABC这将在本地计算机上创建一个新分支。数字结账ABCgitpushorigin ABC这将把这个分支推送到远程存储库,并在git服务器上创建一个分支。你完了。
您可以使用gitk等工具获得项目历史的图形视图。只需运行:
gitk --all
如果要签出特定分支:
git checkout <branch name>
对于特定的提交,使用SHA1哈希而不是分支名称。(请参阅Git社区书中的Treeshes,这是一本好书,以查看导航树的其他选项。)
gitlog也有一整套选项来显示详细或摘要历史。
我不知道在承诺历史上有什么简单的方法可以前进。具有线性历史的项目可能并不那么常见。像SVN或CVS那样的“修订”想法在Git中并不适用。
一种方法是创建所有对补丁的提交。检查初始提交,然后在阅读后按顺序应用补丁。
使用git格式补丁<初始修订版>,然后使用git签出<初始修订版本>。你应该在你的导演中得到一堆文件,以四位数字开始,这是补丁。
当您阅读完修订后,只需执行gitapply<filename>,它应该如下所示git应用0001-*和count。
但我真的很奇怪,为什么你不只是想阅读补丁本身?请在你的评论中发表这一点,因为我很好奇。
git手册还告诉我:
gitshow next~10:文档/README显示文件Documentation/README的内容,因为它们在下一个分支的第10次最后提交中是最新的。
您还可以查看git责备文件名,它为您提供了一个列表,其中每一行都与提交哈希+作者相关联。
推荐文章
- Bower: ENOGIT Git未安装或不在PATH中
- Bitbucket上的Git:总是要求密码,即使上传了我的公共SSH密钥
- Git别名-多个命令和参数
- 如何添加一个“打开git-bash这里…”上下文菜单到windows资源管理器?
- 是否可以在Git中只提取一个文件?
- 当我做“git diff”的时候,我怎么能得到一个并排的diff ?
- 在git中如何将提交移动到暂存区?
- 如何缩小。git文件夹
- 如何在本地删除分支?
- 找到包含特定提交的合并提交
- Windows上Git文件的权限
- 如何从一个枝头摘到另一个枝头
- 如何获得在两次Git提交之间更改的所有文件的列表?
- 什么是跟踪分支?
- 如何在不稳定的连接上完成一个大项目的git克隆?