目录
[1、配置 Git 忽略文件](#1、配置 Git 忽略文件)
1、配置 Git 忽略文件
作用:与项目的实际功能无关,不参与服务器上部署/实际代码的执行。把它们忽略掉能够屏蔽 IDE 工具之 间的差异。
配置步骤:
1、安装.ignore插件
- File --- Setting --- Plugins --- 输入.ignore --- install【安装.ignore插件】
2、创建.gitignore文件
- File --- New --- .ignore file --- .gitignore file (Git) --- 创建.gitignore文件
data:image/s3,"s3://crabby-images/48dff/48dff2933e2d917cf484d528680ae0928d304dff" alt=""
3、编辑.gitignore文件
- 打开.gitignore文件,此时系统已经默认忽略了某些文件;也可以手动添加或删除要忽略的文件。
.gitignore 文件,每行的忽略规则的语法如下:
- 空格不匹配任意文件,可作为分隔符,可用反斜杠转义
- #开头:标识注释,可以使用反斜杠进行转义
- ! 开头:标识否定,该文件将会再次被包含,如果排除了该文件的父级目录,则使用 ! 也不会再次被包含。可以使用反斜杠进行转义
- / 结束:只匹配文件夹以及在该文件夹路径下的内容,但是不匹配该文件
- / 开头:匹配文件
- 如果一个模式不包含斜杠,则它匹配相对于当前 .gitignore 文件路径的内容,如果该模式不在 .gitignore 文件中,则相对于项目根目录
- ** 匹配多级目录,可在开始,中间,结束
- ? 通用匹配单个字符
- [] 通用匹配单个字符列表
常用匹配示例:
- bin/ :忽略当前路径下的bin文件夹,该文件夹下的所有内容都会被忽略,不忽略 bin 文件
- /bin :忽略根目录下的bin文件
- /*.c :忽略 cat.c,不忽略 build/cat.c
- debug/*.obj : 忽略 debug/io.obj,不忽略 debug/common/io.obj 和 tools/debug/io.obj
- **/foo : 忽略/foo, a/foo, a/b/foo等
- a/**/b : 忽略a/b, a/x/b, a/x/y/b等
- !/bin/run.sh : 不忽略 bin 目录下的 run.sh 文件
- *.log : 忽略所有 .log 文件
- config.php : 忽略当前路径的 config.php 文件
4、.gitignore文件更改后不生效怎么办?
原因:新增的忽略文件只对工作区生效,对在暂存区的文件、本地仓库、远程仓库的文件是无效的,所以最好在新建项目之初就新建忽略文件。
解决办法:
- 1、先删除暂存区的文件
- 2、再使用命令 git add . 将本地文件添加到暂存区中
- 3、然后再提交到本地仓库
- 4、最后再推送到远程仓库
git rm -r --cached .
git add .
git commit -m "update .gitignore"
5、pycharm中使用git后的各文件颜色说明:
- 被.ignore忽略的文件,颜色是:黄色
- 在本地工作区的文件,颜色是:红色
- 添加暂存区的文件,颜色是:绿色
- 提交到本地仓库的文件,颜色是:变成正常色 白色
- 推送到远程仓库的文件,颜色是:白色
2、定位Git
1、File->Settings->Git
data:image/s3,"s3://crabby-images/c6abd/c6abd29a1d537181abbdcd670a3da21cb407f605" alt=""
3、使用pycharm本地提交
3.1、初始化本地库
1、VCS->Create Git Repository
data:image/s3,"s3://crabby-images/a1714/a171402b9cfa4c5723e72b1e548135afa4e9b301" alt=""
2、选择需要初始化本地库的文件
data:image/s3,"s3://crabby-images/a18c6/a18c62152d9d9a8485501d7bb79540f2f5abb3d1" alt=""
3、初始化成功后所有文件颜色变成:红色 所有文件待添加到暂存区
data:image/s3,"s3://crabby-images/ba30b/ba30b05638a7e43d42764753c685ab4675116511" alt=""
3.2、添加到暂存区
1、右键项目->Git->Add 将项目添加到暂存区
data:image/s3,"s3://crabby-images/c30f3/c30f39512843cb7cdf697e133ef213b11594504b" alt=""
2、可以看到项目颜色变成绿色,说明已经添加到暂存区了
data:image/s3,"s3://crabby-images/46909/469096cd8c93fc0f7659f956c52ba8324eff481a" alt=""
3.3、提交到本地库
1、右键项目->Git->Commit Directory 将项目提交到本地仓库
data:image/s3,"s3://crabby-images/04840/048403ee8f8a4442be930e152a0af739905e091f" alt=""
2、选择需要提交的项目,并备注提交信息。
data:image/s3,"s3://crabby-images/8fc1f/8fc1fbddeadafdc1d7c52091ff5377d74df871fe" alt=""
3.4、切换版本
1、在 pycharm 的左下角,点击 Git,然后点击 Log 查看版本
data:image/s3,"s3://crabby-images/0a7ff/0a7ff7f0769e45cdc5517d1b0d5330834105a4d1" alt=""
data:image/s3,"s3://crabby-images/36324/36324a3e3680bbd1f57bfc5864422378f344b69e" alt=""
2、选项需要切换的历史版本->右键->Checkout Revision (对应的版本号的前8位)
data:image/s3,"s3://crabby-images/8c01f/8c01ffb967824f7d7ee959e28d0640b306106287" alt=""
3、查看切换版本是否成功
- 切换之前的内容和指针指向情况
data:image/s3,"s3://crabby-images/45d28/45d2888088e1f869093daa1526732e6885928a0c" alt=""
- 切换后的内容和指针指向情况
data:image/s3,"s3://crabby-images/b79ea/b79ea5941e6efe452866adde5834e8c85c623cab" alt=""
4、分支操作
4.1、创建分支
1、项目右键->Git->New Branch 或者 右下角版本号->New Branch
data:image/s3,"s3://crabby-images/0eadd/0eadd3f2df6dea7f813b2e8f03efc7be0fff9119" alt=""
data:image/s3,"s3://crabby-images/0d2ca/0d2cac69e887d61fc0bd798b384b25c41897fc81" alt=""
2、填写分支名称,创建 hot-fix 分支。
data:image/s3,"s3://crabby-images/78311/783111623ffd51063717dd530671139b9453b42a" alt=""
data:image/s3,"s3://crabby-images/296e7/296e7140f0116d3c18f00dbd0d26ca72beb27c21" alt=""
4.2、切换分支
1、项目右键->Git->Bramches->选择需要切换的分支->点击">"->点击Checkout
data:image/s3,"s3://crabby-images/8db88/8db887ff252d3a3c51751a11a4af35ae06f0d742" alt=""
data:image/s3,"s3://crabby-images/e4340/e43406cd060f75d9c6e587e5b58c3199fb6ea39d" alt=""
或者 点击右下角hot-fix分支->点击需要切换的分支->点击Checkout 进行分支切换
data:image/s3,"s3://crabby-images/51389/51389f43015689e0195cda9473c0a20f8b845164" alt=""
2、查看分支是否切换成功
data:image/s3,"s3://crabby-images/53c06/53c06bbfabccd5155f7bd7b4c8adef80f2944a0f" alt=""
4.3、合并分支
1、在 pycharm 窗口的右下角,将 hot-fix 分支合并到当前 master 分支。
- 点击右下角master分支->点击hot-fix分支->点击Merge Selected into Current 进行分支合并
- 如果代码没有冲突,分支直接合并成功,分支合并成功以后,代码自动提交,无需手动 提交本地库。
data:image/s3,"s3://crabby-images/c65fa/c65fa638da55e24d873ef6fb264fb0db42687645" alt=""
5、解决冲突
注意:在实际工作中,在本地合并分支时,通常需要先切换到目标分支(如master
),然后拉取该分支最新的代码,再进行合并操作。
1、如图所示,如果 master 分支和 hot-fix 分支都修改了代码,在合并分支的时候就会发生 冲突。
注意:修改文件一定要先提交到本地仓库,然后切换到master分支,最后把hot-fix分支合并到master分支,再把合并后的代码提交到本地仓库
data:image/s3,"s3://crabby-images/5bda7/5bda7a72ddbf52ec24eb3f03c977f18b78363edd" alt=""
data:image/s3,"s3://crabby-images/d8d99/d8d99e2c895bb9684985b53184f0b5a63a21e609" alt=""
2、切换搭配master 分支,然后合并 hot-fix 分支,就会发生代码冲突。
data:image/s3,"s3://crabby-images/31332/313325e5e04260ef10b397d763231a22be178db0" alt=""
data:image/s3,"s3://crabby-images/b5a04/b5a043cca83c9ee7b1018d7b39227911e8c1d747" alt=""
3、点击Merge按钮,手动合并代码
data:image/s3,"s3://crabby-images/41d23/41d23592c1a3e0a610ee358b486a3ef6547d9d41" alt=""
4、手动合并完代码以后,点击右下角的 Apply 按钮。
data:image/s3,"s3://crabby-images/3e4f6/3e4f6a55430ad4c8b702435649524bdb968b1e3f" alt=""
5、手动合并完成后,需要手动提交到本地仓库
- 过程同上:先添加到暂存区,然后提交到本地仓库
data:image/s3,"s3://crabby-images/594d8/594d8484a77812f48859ef0150ab0892a6dde896" alt=""
data:image/s3,"s3://crabby-images/f2843/f28436607887cd3d509396977a57767e2834bd72" alt=""