Git 教程:解密 .gitignore 文件、合并分支、解决冲突、及 Git 帮助

Git 帮助

如果你忘记了命令或命令的选项,你可以使用 Git 帮助。

在命令行中,有几种不同的使用帮助命令的方式:

  • git command -help - 查看特定命令的所有可用选项
  • git help --all - 查看所有可能的命令

让我们看看不同的命令。

Git -help 查看特定命令的选项

任何时候,如果你需要帮助来记住特定命令的选项,你可以使用 git command -help

这将显示特定命令的所有可用选项:

bash 复制代码
usage: git commit [] [--] ...

    -q, --quiet           suppress summary after successful commit
    -v, --verbose         show diff in commit message template

Commit message options
    -F, --file      read message from file
    --author      override author for commit
    --date          override date for commit
    -m, --message 
                          commit message
    -c, --reedit-message 
                          reuse and edit message from specified commit
    -C, --reuse-message 
                          reuse message from specified commit
    --fixup       use autosquash formatted message to fixup specified commit
    --squash      use autosquash formatted message to squash specified commit
    --reset-author        the commit is authored by me now (used with -C/-c/--amend)
    -s, --signoff         add a Signed-off-by trailer
    -t, --template 
                          use specified template file
    -e, --edit            force edit of commit
    --cleanup       how to strip spaces and #comments from message
    --status              include status in commit message template
    -S, --gpg-sign[=]
                          GPG sign commit

Commit contents options
    -a, --all             commit all changed files
    -i, --include         add specified files to index for commit
    --interactive         interactively add files
    -p, --patch           interactively add changes
    -o, --only            commit only specified files
    -n, --no-verify       bypass pre-commit and commit-msg hooks
    --dry-run             show what would be committed
    --short               show status concisely
    --branch              show branch information
    --ahead-behind        compute full ahead/behind values
    --porcelain           machine-readable output
    --long                show status in long format (default)
    -z, --null            terminate entries with NUL
    --amend               amend previous commit
    --no-post-rewrite     bypass post-rewrite hook
    -u, --untracked-files[=]
                          show untracked files, optional modes: all, normal, no. (Default: all)
    --pathspec-from-file 
                          read pathspec from file
    --pathspec-file-nul   with --pathspec-from-file, pathspec elements are separated with NUL character
Note: You can also use --help instead of -help to open the relevant Git manual page

Git help --all 查看所有可能的命令

要列出所有可能的命令,可以使用 help --all 命令:

注意:这将显示一个非常长的命令列表

bash 复制代码
$ git help --all

这将显示所有可能的命令列表。

合并分支和解决冲突

紧急修复已经准备好,现在让我们合并 master 和 emergency-fix 分支。

首先,我们需要切换到 master 分支:

git checkout master

现在,我们将当前分支(master)与 emergency-fix 合并:

bash 复制代码
git merge emergency-fix
bash 复制代码
更新 09f4acd..dfa79db
快进
index.html | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)

由于 emergency-fix 分支直接来自于 master,并且在我们工作时没有对 master 进行其他更改,Git 将其视为 master 的延续。因此,可以"快进",将 master 和 emergency-fix 指向相同的提交。

由于 master 和 emergency-fix 现在本质上相同,我们可以删除 emergency-fix,因为它不再需要:

bash 复制代码
git branch -d emergency-fix
bash 复制代码
已删除分支 emergency-fix(是 dfa79db)。

合并冲突

现在我们可以切换到 hello-world-images 并继续工作。添加另一个图像文件(img_hello_git.jpg)并更改 index.html,以便显示它:

bash 复制代码
git checkout hello-world-images
html 复制代码
<!DOCTYPE html>
<html>
<head>
<title>Hello World!</title>
<link rel="stylesheet" href="bluestyle.css">
</head>
<body>

<h1>Hello world!</h1>
<div><img src="img_hello_world.jpg" alt="Hello World from Space" style="width:100%;max-width:960px"></div>
<p>This is the first file in my new Git Repo.</p>
<p>A new line in our file!</p>
<div><img src="img_hello_git.jpg" alt="Hello Git" style="width:100%;max-width:640px"></div>

</body>
</html>

现在,我们已经完成了在该分支上的工作,可以为该分支暂存并提交:

bash 复制代码
git add --all
git commit -m "added new image"

我们看到 index.html 在两个分支中都发生了更改。现在我们准备将 hello-world-images 合并到 master 中。但是,我们最近在 master 中所做的更改会发生什么?

bash 复制代码
git checkout master
git merge hello-world-images

自动合并 index.html

合并冲突(内容):index.html 中的合并冲突

自动合并失败;解决冲突,然后提交结果。

合并失败,因为在 index.html 的不同版本之间存在冲突。让我们来检查状态:

bash 复制代码
git status

在 master 分支上,你有未解决的路径。

(解决冲突并运行 "git commit")

(使用 "git merge --abort" 中止合并)

要提交的更改:

新文件:img\_hello\_git.jpg

新文件:img\_hello\_world.jpg

未解决的路径:

(使用 "git add ..." 标记解决)

两者修改:   index.html

这证实了 index.html 中存在冲突,但图像文件已经准备好并暂存以进行提交。

因此,我们需要解决冲突。在编辑器中打开文件:

html 复制代码
<!DOCTYPE html>
<html>
<head>
<title>Hello World!</title>
<link rel="stylesheet" href="bluestyle.css">
</head>
<body>

<h1>Hello world!</h1>
<div><img src="img_hello_world.jpg" alt="Hello World from Space" style="width:100%;max-width:960px"></div>
<p>This is the first file in my new Git Repo.</p>
<<<<<<< HEAD
<p>This line is here to show how merging works.</p>
=======
<p>A new line in our file!</p>
<div><img src="img_hello_git.jpg" alt="Hello Git" style="width:100%;max-width:640px"></div>
>>>>>>> hello-world-images

</body>
</html>

我们可以看到不同版本之间的差异,并按照我们的需求进行编辑:

html 复制代码
<!DOCTYPE html>
<html>
<head>
<title>Hello World!</title>
<link rel="stylesheet" href="bluestyle.css">
</head>
<body>

<h1>Hello world!</h1>
<div><img src="img_hello_world.jpg" alt="Hello World from Space" style="width:100%;max-width:960px"></div>
<p>This is the first file in my new Git Repo.</p>
<p>This line is here to show how merging works.</p>
<div><img src="img_hello_git.jpg" alt="Hello Git" style="width:100%;max-width:640px"></div>

</body>
</html>

现在我们可以暂存 index.html 并检查状态:

bash 复制代码
git add index.html
git status

在 master 分支上,所有冲突都已解决,但你仍在合并中。

(使用 "git commit" 完成合并)

要提交的更改:

新文件:img_hello_git.jpg

新文件:img_hello_world.jpg

修改: index.html

冲突已解决,我们可以使用提交来完成合并:

bash 复制代码
git commit -m "merged with hello-world-images after fixing conflicts"

然后删除 hello-world-images 分支:

bash 复制代码
git branch -d hello-world-images
bash 复制代码
已删除分支 hello-world-images(是 1f1584e)。

现在你对分支和合并的工作方式有了更好的了解。是时候开始与远程仓库一起工作了!

Git .gitignore 文件:创建、示例规则和模式匹配

.gitignore 文件是用于指定 Git 忽略的文件和文件夹的配置文件。这意味着 Git 不会跟踪或包含在版本控制中,但它们仍然存在于你的工作目录中。以下是关于.gitignore文件的详细信息:

创建**.gitignore**文件

要创建一个.gitignore文件,请按照以下步骤操作:

  1. 打开终端或命令行工具。
  2. 导航到你的 Git 存储库的根目录。
  3. 创建.gitignore文件。你可以使用以下命令:touch .gitignore。这将在存储库的根目录中创建一个.gitignore文件。
  4. 使用文本编辑器打开.gitignore文件,你可以添加你要忽略的文件和文件夹的规则。

示例 .gitignore 文件

下面是一个示例.gitignore文件的内容,演示了一些忽略规则:

log 复制代码
# 忽略所有 .log 文件
*.log

# 忽略任何名为 "temp" 的目录中的所有内容
/temp/

# 忽略所有 .zip 和 .rar 压缩文件
*.zip
*.rar

# 忽略特定文件
config.txt

# 忽略特定文件夹及其内容
bin/
build/

这个.gitignore文件包含了各种忽略规则,例如忽略所有.log文件、名为"temp"的目录、.zip.rar压缩文件、config.txt文件以及bin/build/文件夹及其内容。

.gitignore 文件的规则如下:

  • 模式匹配:.gitignore中的规则使用模式匹配来匹配文件和文件夹。
  • 行注释:以#开头的行将被视为注释。
  • 文件匹配:你可以使用*来匹配任何字符,?来匹配单个字符,[]来匹配字符集,[!...]来否定字符集。
  • 目录匹配:如果模式以/结尾,则该模式仅匹配目录。
  • 递归匹配:使用``来匹配任何子目录。
  • 否定规则:使用!符号来否定已定义的规则。

示例规则包括:

  • *.log:忽略所有扩展名为.log的文件。
  • /temp/:忽略名为"temp"的目录及其内容。
  • bin/:忽略名为"bin"的文件夹及其内容。
  • !important.log:忽略所有.log文件,但不包括名为"important.log"的文件。

通过编辑.gitignore文件,你可以自定义哪些文件和文件夹应该被 Git 忽略,以便它们不会包含在版本控制中。这对于避免将不必要的或敏感文件提交到版本控制中非常有用。

最后

为了方便其他设备和平台的小伙伴观看往期文章:

微信公众号搜索:Let us Coding,关注后即可获取最新文章推送

看完如果觉得有帮助,欢迎 点赞、收藏、关注

相关推荐
PetterHillWater几秒前
基于Trae智能复杂项目重构实践
后端·aigc
凌览14 分钟前
有了 25k Star 的MediaCrawler爬虫库加持,三分钟搞定某红书、某音等平台爬取!
前端·后端·python
这里有鱼汤26 分钟前
给你的DeepSeek装上实时行情,让他帮你炒股
后端·python·mcp
咖啡啡不加糖28 分钟前
暴力破解漏洞与命令执行漏洞
java·后端·web安全
风象南31 分钟前
SpringBoot敏感配置项加密与解密实战
java·spring boot·后端
ん贤1 小时前
RESTful风格
后端·go·restful
Humbunklung1 小时前
Rust方法语法:赋予结构体行为的力量
开发语言·后端·rust
萧曵 丶1 小时前
Rust 内存结构:深入解析
开发语言·后端·rust
Kookoos1 小时前
ABP VNext + Cosmos DB Change Feed:搭建实时数据变更流服务
数据库·分布式·后端·abp vnext·azure cosmos
前端小巷子1 小时前
Web开发中的文件下载
前端·javascript·面试