java.util.regex.Matcher; import java.util.regex.Pattern; import java.util.stream.Collectors; /** * 删除未使用的类...|conf|yml)|services$"); private static final Pattern EXCLUDE_PATTERN = Pattern.compile("target|.git..."); /** * 添加自行定义的会被调用到的注解或关键字 */ private static final Pattern USED_PATTERN = Pattern.compile
完全是被推着一步步在学git操作! 删除单个文件 如果只是删除本地的一个文件,通常是物理删除,然后git删除,再提交即可。...rm test.txt git status git rm test.txt git commit -m "remove test.txt" git push 还原那些误删的文件 另一种情况是删错了...,因为版本库里还有呢,所以可以很轻松地把误删的文件恢复到最新版本: $ git checkout -- test.txt git checkout其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除...批量删除多个文件 在项目根目录使用命令git add -A然后使用命令git commit -m "del" 再然后要使用 git push推送到远程服务器 建议每一次add之后再次使用git status...命令来查看是否已经stage了 如果你要上传删除(全部上传) git add --all
在Git中,删除也是一个修改操作,我们实战一下,先添加一个新文件test.txt到Git并且提交: $ git add test.txt $ git commit -m "add test.txt"...,或者用rm命令删了: $ rm test.txt 这个时候,Git知道你删除了文件,因此,工作区和版本库就不一致了,git status命令会立刻告诉你哪些文件被删除了: $ git status On...小提示:先手动删除文件,然后使用git rm 和git add效果是一样的。...注意:从来没有被添加到版本库就被删除的文件,是无法恢复的! 小结 命令git rm用于删除一个文件。...总之,就是让这个文件回到最近一次git commit或git add时的状态。
使用git的时候 , 如果我们在自己的工作区中修改了代码 , 既没有git add , 更没有git checkout , 想要恢复成修改之前的样子 用 git checkout git checkout...文件 , 恢复某个文件
git 不再追踪文件改动 git update-index --assume-unchanged filePath git 恢复追踪文件改动 git update-index —no-assume-unchanged...filePath git 删除被管理的文件 #不会删除本地文件 git rm —-cached filePath git 删除被管理的文件夹 git rm -r -f —-cached filePath
今天上传代码的时候忘记写 gitignore 了,一不小心把 node_modules 也传上去了,这破玩意体积巨大,所以要从上面删除。...执行命令: git rm -r --cached admin/node_modules git commit -m "删除node_modules" ? 下次 push 代码的时候就会发现已经删掉了。
刚接触 git 的时候,当碰到之前删除某个文件(比如图片)后面开发又需要恢复的时候,会采取非常笨的方法。从某一个文件存在的 commit 切换出一个新的分支,再将需要的某个文件拷贝出来。...git 其实本身就可以恢复被删除的文件。几个命令就可以了。 大多数我们是不知道在何时删除了某个文件,通过下面这个命令我们可以查看在哪个 commit 中删除了哪些文件。...git log --diff-filter=D --summary 执行这个命令后效果如下: ?...比如我想恢复 ic_selected.png 这个文件,我们可以看到删除该文件对应的 commit id :f541888b0e7255cc6aa22a277f3dd9fe5502e5e2。...接下来我们执行下面这个命令 git checkout $commit~1 filename 这个命令会检出该 commit 的上一个提交中的文件,因为我们是在该 commit 中删除的文件,所以需要在上一个
Git 是一个很好的版本控制工具,当然驾驭起来相比 SVN 要稍微复杂一些。初入 Git,难免有一些问题。比如我们不小心将某个文件加入了版本控制,但是突然又不想继续跟踪控制这个文件了,怎么办呢?...其实方法也是很简单的。使用git update-index即可。...不想继续追踪某个文件 1 git update-index --assume-unchanged your_file_path 如果想再次继续跟踪某个文件 1 git update-index --no-assume-unchanged
error: RPC failed; curl 56 OpenSSL SSL_read: SSL_ERROR_SYSCALL, errfno 10054 方法1: 改成ssh推送 方法2: 把推送的缓存扩大...#首先设置通信缓存大小 git config http.postBuffer 524288000 #然后把缓存清除 git filter-branch --index-filter 'git rm...-r --cached --ignore-unmatch ' HEAD 两个方法都试过,可以用的。
用 git rm 来删除文件,同时还会将这个删除操作记录下来; 用 rm 来删除文件,仅仅是删除了物理文件,没有将其从 git 的记录中剔除。...直观的来讲,git rm 删除过的文件,执行 git commit -m "abc" 提交时,会自动将删除该文件的操作提交上去。...而用 rm 命令直接删除的文件,单纯执行 git commit -m "abc" 提交时,则不会将删除该文件的操作提交上去,需要在执行commit的时候,多加一个-a参数, 即rm删除后,需要使用git...commit -am "abc"提交才会将删除文件的操作提交上去。...比如: 1)删除文件test.file git rm test.file git commit -m "delete test.file" git push 或者 rm test.file git commit
Git是用来管理源代码的一个工具,很多时候,我们不想让Git来跟踪较大的二进制文件。...但是如果不小心将某个文件加入到Git的缓存区后,不管后面怎么删除这个大文件,Git始终都保存有这个文件的历史记录,因此项目会很大。...即使使用git rm命令删除当前的cnn.model文件,.git目录中还是记录有这个大文件的记录,因此后面别人clone这个项目后,项目还是很大。...因此这里需要使用git filter-branch命令来删除.git目录中的文件记录: $ git filter-branch --index-filter 'git rm -r --cached -...如果git push提示冲突的话,需要用git push -f命令来强制推送代码到远端。
不小心将项目中一个文件夹删除还未提交,或者已经提交, 此时想要恢复数据该怎么办? 答案是git reflog,使用git reflog命令可以帮助恢复git误操作,进行数据恢复。...操作过程: 打开终端命令行,进入到项目目录,输入git reflog,可以得到如下结果: ?...git记录每次修改head的操作,git reflog/git log -g可以查看所有的历史操作记录,然后通过git reset命令进行恢复。 ...想要将代码恢复到"ssm-login初始化"时的版本,此时的head记录值为"b40839f",输入如下命令即可: git reset --hard b40839f 误删数据回来啦!
命令 , 创建标签 , 并附加说明文字 ; 执行 git tag 命令 , 查询标签 ; 执行 git show v0.9 命令 , 查询标签的详细信息 ; 完整的执行过程 : D:\Git\git-learning-course...5 二、推送单个标签到远程仓库 执行 git push origin v0.9 命令 , 可以将标签推送到远程仓库 ; 执行过程 : D:\Git\git-learning-course>git push...* [new tag] v0.9 -> v0.9 三、推送所有标签到远程仓库 执行 git push origin --tags 命令 , 可以一次性将所有标签推送到远程仓库 ;...四、删除远程仓库的标签 执行 git tag -d v0.9 命令 , 删除本地的标签 ; 然后执行 git push origin :refs/tags/v0.9 命令 , 删除远程仓库中的标签 ,...注意标签的拼接格式 , " git push origin :refs/tags/ " + 标签名称 ; 此时 , 远程仓库中的标签 , 也被删除了 ; 执行过程 : D:\Git\git-learning-course
我们经常会在配置文件里留下一些敏感信息 比如数据库链接字符串的用户名和密码 如果不提交配置文件到github或者其他源码管理网站 那么你的粉丝很可能就无法正确运行你的项目,就达不到开源的目的了 那么,怎么让...git在提交一次配置文件之后就不再跟踪配置文件的变化了呢 (一般第一次提交的配置文件是脱敏的) 只要这样做: git update-index --skip-worktree [文件绝对路径] 即可
删除已经提交的.idea文件夹 git pull origin master # 将远程仓库里面的项目拉下来 //--cached不会把本地的test删除 git...rm -r --cached .idea # 删除.idea文件夹 git commit -m '删除.idea' # 提交,添加操作说明 git push -u...origin master # 将本次更改更新到github项目上去 git忽略某个目录或文件不上传 在.gitignore文件加调用文件夹/文件 node_modules...# 忽略文件夹 *.map # 忽略所有以.map结尾文件 .DS_Store /node_modules /dist /unpackage /.hbuilderx /tests/e2e/videos
可以使用以下方式删除仓库中的 .idea 文件。 1....删除项目重新 push(不推荐) 仓库里面的应用删除掉 本地应用中的 .git 文件删除掉 先添加 .gitignore 文件,然后 push 代码到仓库 这种方式比较适合在最开始的时候,如果有了很多...因为删除仓库之后再 git add 会被当成一次提交。 可以考虑使用下面的方式。...2. git 删除本地暂存区文件 修改 .gitignore 文件内容,添加 .idea 删除本地暂存区中的 .idea 文件 git rm --cached -r .idea 推到远端 git commit...同样,除了 .idea 文件,其他文件都可以使用这种方式删除。 补充 关于 .gitignore 可以使用 IDEA 的插件 .ignore,可以在创建 .ignore 文件时勾选相关配置。
situation 用git checkout切换本地分支从b1到b2时, 如果b1的本地文件有修改, 会发生冲突。...(b1和b2不在一个commit id上) 设b1和b2都有123.txt这个文件(这2个branch下123.txt文件内容可相同可不相同); 当前在b1下, 修改了一行123.txt, 然后想git...实际的应用场景是这样:假设你有分支master和develop。master用来release版本,develop用来开发。master上release了版本1,然后develop继续开发。...如果你在develop上开发到一半的时候,release的版本1发现了bug。这个时候,你develop分支有未提交的修改,然后你需要切换到master上的版本1进行修复。...这个时候切换到master分支,肯定是不需要把develop分支上的修改带过去的。
推荐三款工具,可根据项目情况进行选型: PurgeCSS PurgeCSS 通过分析你的内容和 CSS 文件,首先它将 CSS 文件中使用的选择器与内容文件中的选择器进行匹配,然后它会从 CSS 中删除未使用的选择器...由于其能够模拟 HTML 和 JavaScript 的执行,UnCSS 可以有效地从 web 应用程序中删除未使用的选择器。 但是,其模拟行为可能会在性能和实用性方面带来成本消耗。...例如,要从 Pug 模板文件中删除未使用的 CSS,你需要将 Pug 转换为 HTML 并在 jsdom 中模拟页面。...目前,在删除未使用的 CSS 方面,UnCSS 在某些情况下可能是最准确的工具。...提取器是一个函数,它的作用是根据文件内容提取文件中使用所有的 CSS 选择器。它可以完美地删除未使用的 CSS。
git 不再追踪文件改动 git update-index –assume-unchanged filePath git 恢复追踪文件改动 git update-index —no-assume-unchanged...filePath git 删除被管理的文件 git rm —cached filePath git 删除被管理的文件夹 git rm -r -f —cached filePath Git 是一个很好的版本控制工具...初入 Git,难免有一些问题。比如我们不小心将某个文件加入了版本控制,但是突然又不想继续跟踪控制这个文件了,怎么办呢? 其实方法也是很简单的。使用git update-index 即可。...不想继续追踪某个文件 git update-index --assume-unchanged your_file_path 如果想再次继续跟踪某个文件 git update-index --no-assume-unchanged
参考文章: 解决.gitignore文件忽略规则无效git依然跟踪修改的问题
领取专属 10元无门槛券
手把手带您无忧上云