首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
第 10章 编写高效的函数
10.1 函数名
10.2 函数大小的权衡
10.3 函数的形参和实参
10.3.1 默认参数
10.3.2 使用*和**向函数传参
10.3.3 使用*创建可变参数函数
10.3.4 使用**创建可变参数函数
10.3.5 使用*和**创建包装函数
10.4 函数式编程
10.4.1 副作用
10.4.2 高阶函数
10.4.3 lambda 函数
10.4.4 在列表推导式中进行映射和过滤
10.5 返回值的数据类型应该不变
10.6 抛出异常和返回错误码
第 11章 注释、文档字符串和类型提示
11.1 注释
11.1.1 注释风格
11.1.2 内联注释
11.1.3 说明性的注释
11.1.4 总结性的注释
11.1.5 “经验之谈”的注释
11.1.6 法律注释
11.1.7 注释的专业性
11.1.8 代码标签和TODO 注释
11.1.9 神奇的注释和源文件编码
11.2 文档字符串
11.3 类型提示
11.3.1 使用静态分析器
11.3.2 为多种类型设置类型提示
11.3.3 为列表、字典等设置类型提示
11.3.4 通过注释向后移植类型提示
第 12章 通过Git管理项目
12.1 Git 提交和仓库
12.2 使用Cookiecutter新建Python项目
12.3 安装Git
12.3.1 配置Git 用户名和电子邮件
12.3.2 安装GUI Git 工具
12.4 Git 的工作流程
12.4.1 Git 是如何追踪文件状态的
12.4.2 为什么要暂存文件
12.5 在计算机上创建Git 仓库
12.5.1 添加供Git 追踪的文件
12.5.2 忽略仓库中的文件
12.5.3 提交修改
12.5.4 从仓库中删除文件
12.5.5 重命名和移动仓库中的文件
12.6 查看提交日志
12.7 恢复历史修改
12.7.1 撤销未提交的本地修改
12.7.2 取消暂存的文件
12.7.3 回滚近期的提交
12.7.4 回滚到单个文件的某次提交
12.7.5 重写提交历史
12.8 GitHub 和git推送命令
12.8.1 将一个已存在的仓库推送到GitHub
12.8.2 克隆已存在的GitHub仓库
当前位置:
首页>>
技术小册>>
Python编程轻松进阶(四)
小册名称:Python编程轻松进阶(四)
### 12.1 Git 提交和仓库 在软件开发领域,版本控制是不可或缺的一环,它帮助开发者跟踪代码的变更历史,促进团队协作,以及管理项目的多个版本。Git 作为目前最流行的分布式版本控制系统,以其高效、灵活和强大的特性赢得了全球开发者的青睐。本书《Python编程轻松进阶(四)》的本章“12.1 Git 提交和仓库”将深入讲解 Git 的基础操作,特别是关于如何有效地进行提交和管理仓库。 #### 12.1.1 Git 简介 在深入探讨 Git 提交和仓库之前,先简要回顾一下 Git 的基本概念。Git 是一个开源的分布式版本控制系统,由林纳斯·托瓦兹(Linux 之父)于 2005 年首次发布。与集中式版本控制系统(如 SVN)不同,Git 允许每个开发者在自己的计算机上拥有一个完整的项目历史副本,从而提高了开发的灵活性和效率。 Git 的核心概念包括仓库(Repository)、工作目录(Working Directory)、暂存区(Staging Area,也称 Index 或 Stage)和提交(Commit)。仓库是存储项目所有版本信息的地方;工作目录是你在其中编辑文件的本地目录;暂存区是一个中间区域,用于存放即将被提交的更改;而提交则是将暂存区的更改永久保存到仓库中的操作。 #### 12.1.2 初始化 Git 仓库 在开始学习如何提交之前,首先需要有一个 Git 仓库。你可以在一个已存在的项目目录中初始化一个新的 Git 仓库,也可以创建一个全新的目录作为仓库的起点。 ```bash # 在当前目录下初始化 Git 仓库 git init # 或者,在创建新目录的同时初始化仓库 mkdir myproject cd myproject git init ``` 执行 `git init` 命令后,Git 会在当前目录下创建一个名为 `.git` 的隐藏目录,这个目录包含了所有关于版本控制的信息。 #### 12.1.3 添加文件到暂存区 在 Git 中,所有修改过的文件都需要先被添加到暂存区,然后才能被提交到仓库。这一过程确保了开发者能够精确地控制哪些更改被包含在当前的提交中。 ```bash # 将文件添加到暂存区 git add filename # 或者,添加当前目录下的所有文件(不包括以点`.`开头的隐藏文件) git add . ``` 使用 `git add` 命令时,你可以指定单个文件名,也可以使用通配符或 `.` 来匹配多个文件。 #### 12.1.4 提交更改 一旦文件被添加到暂存区,你就可以使用 `git commit` 命令来提交这些更改了。提交时,通常需要提供一个描述性的提交信息,以便将来回顾或追踪更改的原因。 ```bash # 提交暂存区的更改,并附上提交信息 git commit -m "Initial commit" ``` `-m` 选项后面跟的是提交信息,这是一个良好的实践,因为它让其他开发者(或未来的你)能够快速了解每次提交的目的和内容。 #### 12.1.5 查看提交历史 随着时间的推移,仓库中会积累大量的提交。为了了解项目的变更历史,你可以使用 `git log` 命令来查看提交记录。 ```bash # 查看提交历史 git log # 简化输出,只显示提交哈希和提交信息 git log --oneline ``` `git log` 命令提供了丰富的选项来定制输出内容,如 `--author` 可以过滤出指定作者的提交,`--grep` 可以根据提交信息搜索提交等。 #### 12.1.6 分支管理 虽然本节的重点是提交和仓库,但值得一提的是,Git 的分支功能与其提交系统紧密相连。分支允许你在不影响主代码库的情况下进行新功能的开发或错误的修复。 ```bash # 创建一个新分支 git branch new-feature # 切换到新分支 git checkout new-feature # 或者使用更简洁的命令(Git 2.23 版本后推荐使用) git switch new-feature # 在新分支上工作并提交更改 # ... # 切换回主分支 git switch main # 将新分支的更改合并到主分支 git merge new-feature ``` 通过分支管理,Git 使得并行开发和代码合并变得简单而高效。 #### 12.1.7 提交的最佳实践 - **频繁提交**:小步快跑,频繁提交可以帮助你更好地跟踪和管理更改。 - **有意义的提交信息**:确保提交信息清晰、简洁且具有描述性,这有助于其他开发者(或未来的你)理解每次提交的目的。 - **使用分支**:对于新功能或错误修复,尽量在分支上进行开发,避免在主分支上直接修改。 - **代码审查**:在合并到主分支之前,进行代码审查可以确保代码质量,并促进团队成员之间的交流和协作。 #### 12.1.8 远程仓库 虽然 Git 是一个分布式版本控制系统,但通常我们还需要与远程仓库(如 GitHub、GitLab 或 Bitbucket)进行交互,以便在团队成员之间共享代码。 ```bash # 关联远程仓库 git remote add origin https://github.com/username/repo.git # 推送本地分支到远程仓库 git push -u origin main # 从远程仓库拉取最新更改 git pull origin main ``` 远程仓库不仅是一个代码共享的平台,还提供了问题跟踪、代码审查、持续集成/持续部署(CI/CD)等高级功能,极大地促进了软件开发的效率和质量。 #### 结语 通过本章的学习,你应该已经掌握了 Git 提交和仓库的基本操作,包括初始化仓库、添加文件到暂存区、提交更改、查看提交历史、分支管理以及远程仓库的交互。Git 的强大功能远不止于此,但掌握了这些基础知识后,你将能够更有效地使用 Git 来管理你的项目,并与其他开发者协作。随着实践的深入,你将逐渐发现 Git 的更多高级特性和最佳实践,从而进一步提升你的开发效率和项目质量。
上一篇:
第 12章 通过Git管理项目
下一篇:
12.2 使用Cookiecutter新建Python项目
该分类下的相关小册推荐:
Python编程轻松进阶(三)
Python合辑5-格式化字符串
Python编程轻松进阶(一)
Python高性能编程与实战
Python机器学习实战
Python合辑6-字典专题
Python编程轻松进阶(五)
Python3网络爬虫开发实战(上)
机器学习算法原理与实战
Python爬虫入门与实战开发(下)
Python合辑3-字符串用法深度总结
Python合辑2-字符串常用方法