首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Git从某个分支的某次提交新建分支拉取代码

    最近有个项目比较乱,新功能没有做完,develop 分支不能合并到主干,又有新的需求需要修改,但是 master 主干分支的代码又不够新。...只能从 develop 分支的某一次提交上拉取代码,到本地分支,然后进行修改,再提交合并到 master 分支。...Git 拉取某一次提交的代码版本到本地分支: git checkout -b 分之名 远程仓库的commitId 示例: git checkout -b w3h5 af161ecbd13eff1630c14f84a7395d46f5d18888...如果你是第一次参与这个项目,操作步骤如下: 首先克隆分支,将代码拉下来: git clone https://github.com/ideshun/project.git 然后进行代码版本的拉取: git...GitLab ,可以直接 复制提交 SHA 到剪切板。

    9.4K20

    git 从别的分支复制文件或目录

    有时候我们需要从别的分支复制文件或者目录,这里总结一些简单的命令供查看。...假设我们的当前分支为branch1, 想要复制文件或者目录的分支为branch2, 两个分支下文件结构是不同的,具体如下: branch1: ├── README.md ├── cpp │   ├──...如果当前进入了cpp 子目录,后面的路径也需要改成相对路径: git checkout branch2 -- ...../java/test.java 如果想要复制整个目录,也是一样的: git checkout branch2 -- java 此外还可以利用提交的hash值来复制文件,这样就会复制当次提交时候的文件内容...: git checkout 941b6dd java/test.java 参考: https://www.tutsway.com/how-to-copy-file-or-folder-from-one-branch-to-another-in-git.php

    36320

    如何删除错误提交的 git 大文件

    那么如何把这个压缩包彻底从 git 删除? 如果需要删除 git 的历史记录,使用方法很简单,请看 Git如何永久删除文件(包括历史记录) - shines77 - 博客园 。...当然这个方法需要很长时间,因为提交大文件的时间不长,所以可以使用walterlv的方法 彻底删除 Git 仓库中的文件避免占用大量磁盘空间 - walterlv 于是远程仓库删好了,但是本地仓库还是有小伙伴拉下来...git gc --prune=now 第一句代码git fetch -f -p的作用就是从本地拿到远程最新分支,覆盖本地存放的远程分支 第二句实际上因为主要开发分支就是 dev 分支,小伙伴就是把大文件合并到这个分支...删除原来分支,这样就好 最后的命令是使用 gc 清掉这个提交 这时候查看自己的git 文件夹,如果文件夹还是那么大,那么说明还有一个分支是引用提交大文件,需要自己去看一下是哪个分支。...需要说明,git 如果提交一个文件,然后删除他,继续提交,那么这个文件是存在 git 中,需要使用特殊的命令才可以删除。

    3.1K10

    git 在切换分支时有未提交的文件,怎么办? git stash

    situation 用git checkout切换本地分支从b1到b2时, 如果b1的本地文件有修改, 会发生冲突。...(b1和b2不在一个commit id上) 设b1和b2都有123.txt这个文件(这2个branch下123.txt文件内容可相同可不相同); 当前在b1下, 修改了一行123.txt, 然后想git...checkout b2切换到b2分支, 就会提示冲突!...实际的应用场景是这样:假设你有分支master和develop。master用来release版本,develop用来开发。master上release了版本1,然后develop继续开发。...这个时候,你develop分支有未提交的修改,然后你需要切换到master上的版本1进行修复。这个时候切换到master分支,肯定是不需要把develop分支上的修改带过去的。

    3K20

    git 提交文件中的部分修改

    概述 在 Git 提交一个文件的时候,有时候会在同一个文件中,包含两个不同功能的修改,或者一个功能完成了,而别的部分还没有完善不应该进入代码库,这时候如果使用git add file-name的话,会将这个文件中的所有更新都提交...针对这种场景,git 提供了更细粒度的提交命令git add -p,可以分部分提交一个文件中的更新代码块,实测能满足常见的需求。这里简要记录一下如何使用这个命令。 2....实现命令 2.1 原理解释 git 中用”hunk”来表示一个文件中邻近区域中的代码修改块,比如用git diff 查看修改时,两个@@符号分割的一个区域就是一个hunk,其中行首是-,颜色为红色的为删去的行...图片 需要注意的是,git有一套默认的将文件中所有修改分成不同hunk的机制,但我们也可以将默认机制分的太大的hunk分割为多个小的hunk,这样能更精确地控制提交的粒度。...部分提交文件修改的原理简单来说是将所有的修改分成不同的hunk,通过对每个hunk来进行是否提交的判断,从而完成我们的需求。具体命令下面详细讲述。

    37620

    【Git】Git 版本管理 ( 补充提交版本 git commit --amend | 版本库提取文件 git checkout -- filename | 删除文件 git rm )

    文章目录 一、补充提交版本 git commit --amend 二、版本库提取文件 git checkout -- filename 三、删除文件 git rm 一、补充提交版本 git commit...git status 查询 , 发现提交成功 ; 二、版本库提取文件 git checkout – filename ---- git checkout -- filename 命令的作用是 , 从版本库中取出...执行 git checkout -- file1.txt 命令 , 会从版本库中取出最近一次提交的 file1.txt 文件 , 并使用该文件覆盖当前目录的 file1.txt 文件 ; 注意..., 该操作会覆盖掉当前的 filename 文件 , 如果当前 filename 文件有改动 , 但是没有提交 , 一旦执行该命令 , 该文件就会永久被删除 ; 三、删除文件 git rm ---- 将...file3.txt 文件删除 , 先执行 git rm file3.txt 命令 , 删除该文件 , 然后执行 git commit -m "remove file3.txt" 命令 , 将删除文件信息提交到

    57030

    git 禁止大文件提交到仓库中

    方式 1 在服务器进行设置 如这里(gitlab 服务搭建小记)提到的 但是,这个只能限制提交到服务器,本地提交代码时无法拦截 方式 2 使用 git hooks 编写 git hooks 脚本 以下脚本来自...:Git禁止大文件提交到仓库中 | Yunfeng’s Simple Blog 修改仓库下的 .git/hooks/pre-commit 为如下内容(如果没有这个文件请新建) #!...)) echo git hooks copy finish:: pause 大致的文件夹结构 \----\----\githooks\--------pre-commit\--------install.bat...运行 install.bat, 会将 githooks 中的全部文件(除了 install.bat 文件本身)拷贝到 .git\hooks 目录中 遗憾的是,需要手动运行 install.bat,可以结合具体项目情况...,找个时机自动调用 install.bat 比如前端项目可以使用 husky 参考 Git禁止大文件提交到仓库中 | Yunfeng’s Simple Blog 原文链接: https://blog.jgrass.cc

    6400

    IDEA中对Git的常规操作(合并,提交,新建分支,更新)

    工作中多人使用版本控制软件协作开发,常见的应用场景归纳如下: 假设小组中有两个人,组长小张,组员小袁 场景一:小张创建项目并提交到远程Git仓库 场景二:小袁从远程Git仓库上获取项目源码 场景三:小袁修改了部分源码...,提交到远程仓库 场景四:小张从远程仓库获取小袁的提交 场景五:小袁接受了一个新功能的任务,创建了一个分支并在分支上开发 场景六:小袁把分支提交到远程Git仓库 场景七:小张获取小袁提交的分支 场景八:...下图是Git与提交有关的三个命令对应的操作,Add命令是把文件从IDE的工作目录添加到本地仓库的stage区,Commit命令把stage区的暂存文件提交到当前分支的仓库,并清空stage区。...Push命令把本地仓库的提交同步到远程仓库。 ? IDEA中对操作做了一定的简化,Commit和Push可以在一步中完成。 具体操作,在项目上点击右键,选择Git菜单 ? ? ?...请参考场景一 场景四:小张从远程仓库获取小袁的提交 获取更新有两个命令:Fetch和Pull,Fetch是从远程仓库下载文件到本地的origin/master,然后可以手动对比修改决定是否合并到本地的master

    4.9K31

    Git禁止大文件提交到仓库中

    概述 Git提交的时候,有的时候很容易将目录下的非源代码的文件(如二进制文件、模型等)提交到Git仓库里,给后续的使用造成麻烦。...那么有没有一种方法来限制提交到Git的文件的大小呢,答案是Yes,下面我来大概介绍下吧。 原理是利用Git的钩子来在commit之前执行一个脚本,在这个脚本里对提交的文件大小进行检查。...具体操作是:修改仓库下的.git/hooks/pre-commit为如下内容(如果没有这个文件请新建): #!...需要注意的是,.git目录下的文件Git是没有跟踪的,因此在别的电脑或目录下git clone仓库后,pre-commit文件并不会被自动clone进来,需要手动添加。...我在GitHub Gist上提交了这个文件,有需要的小伙伴可以直接下载使用。

    1.8K10

    删除Git仓库中的大文件

    但是如果不小心将某个文件加入到Git的缓存区后,不管后面怎么删除这个大文件,Git始终都保存有这个文件的历史记录,因此项目会很大。...即使使用git rm命令删除当前的cnn.model文件,.git目录中还是记录有这个大文件的记录,因此后面别人clone这个项目后,项目还是很大。...因此这里需要使用git filter-branch命令来删除.git目录中的文件记录: $ git filter-branch --index-filter 'git rm -r --cached -...first commit 重写所有修改这个文件的提交 找到所有修改这个对象的commit后,我们找到最早的修改,然后使用git filter-branch命令来操作,具体如下: $ git filter-branch...,直接从所有提交中删除这个对象: $ git filter-branch --index-filter 'git rm --cached --ignore-unmatch data/model-400M.caffemodel

    6.1K51
    领券