一、准备工作

1. 安装 Git

  • Windows:下载安装包
  • macOS:在终端运行 brew install git
  • Linux
# Ubuntu/Debian
sudo apt update && sudo apt install git# CentOS/Fedora
sudo yum install git

2. 配置用户信息(首次使用)

git config --global user.name "你的名字"
git config --global user.email "你的邮箱"

3. 创建代码仓库(本地)

# 1. 打开终端/命令提示符
# 2. 进入项目目录
cd /path/to/your/project# 3. 初始化Git仓库
git init

二、添加项目文件到Git

1. 创建 .gitignore 文件(重要!)

在项目根目录创建 .gitignore 文件,内容示例:

# 忽略系统文件
.DS_Store
Thumbs.db# 忽略编辑器文件
.idea/
.vscode/
*.swp# 忽略Python虚拟环境
venv/
.env# 忽略编译文件
__pycache__/
*.pyc

2. 添加文件到暂存区

# 添加所有文件(排除.gitignore中的文件)
git add .# 或者添加特定文件
git add file1.py file2.js

3. 查看当前状态

git status

绿色文件表示已添加到暂存区,红色文件表示未跟踪

三、创建首次提交

git commit -m "项目初始提交"

四、创建远程仓库(以GitHub为例)

1. 创建GitHub账号

访问 github.com 注册账号

2. 创建新仓库

  1. 点击右上角 ➕ > New repository
  2. 填写仓库名称(建议与项目名一致)
  3. 选择 Public(公开)或 Private(私有)
  4. 不要勾选 “Initialize this repository with a README”
  5. 点击 Create repository

五、连接本地与远程仓库

1. 获取远程仓库URL

创建成功后,复制显示的HTTPS或SSH URL:

https://github.com/你的用户名/仓库名.git

2. 添加远程仓库

git remote add origin https://github.com/你的用户名/仓库名.git

3. 验证连接

git remote -v
# 应显示:
# originhttps://github.com/你的用户名/仓库名.git (fetch)
# originhttps://github.com/你的用户名/仓库名.git (push)

六、推送代码到远程仓库

git push -u origin main

第一次推送使用 -u 参数设置跟踪关系

七、后续开发工作流

1. 日常开发流程

# 1. 修改文件
# 2. 查看修改状态
git status# 3. 添加修改到暂存区
git add 修改的文件名
# 或添加所有修改
git add .# 4. 提交更改
git commit -m "描述本次修改的内容"# 5. 推送到远程
git push

2. 常用命令速查

命令用途
git diff查看未暂存的修改
git log查看提交历史
git pull拉取远程更新
git branch查看分支
git checkout -b 新分支创建新分支

八、重要注意事项

1. 避免上传敏感信息

  • 不要在代码中包含密码、API密钥等
  • 使用环境变量管理敏感信息
  • 如果误上传了敏感信息:
  1. 立即删除文件
  2. 修改所有相关密钥
  3. 使用 git filter-branch 从历史记录中清除

2. 提交规范

  • 提交信息要清晰描述修改内容
  • 使用动词开头:“添加”、“修复”、"更新"等
  • 示例:
git commit -m "修复用户登录失败的问题"
git commit -m "添加用户管理模块"

3. 分支管理策略

# 创建功能分支
git checkout -b feature/new-module# 开发完成后合并到主分支
git checkout main
git merge feature/new-module# 删除已合并的分支
git branch -d feature/new-module

九、遇到问题怎么办?

常见问题解决:

  1. 认证失败
  • 使用SSH代替HTTPS
  • 生成SSH密钥:ssh-keygen -t ed25519 -C "your_email@example.com"
  • 将公钥(~/.ssh/id_ed25519.pub)添加到GitHub账户设置
  1. 文件冲突
# 拉取最新代码时解决冲突
git pull
# 手动解决冲突后
git add 冲突文件
git commit -m "解决合并冲突"
  1. 撤销修改
# 撤销未暂存的修改
git checkout -- 文件名# 撤销已暂存未提交的修改
git reset HEAD 文件名

十、高级技巧(可选)

1. 使用Git GUI工具

  • GitKraken
  • Sourcetree
  • VS Code内置Git功能

2. 设置自动化钩子

.git/hooks 中添加脚本:

# pre-commit 示例(提交前运行测试)
#!/bin/sh
pytest tests/
if [ $? -ne 0 ]; then
echo "测试失败,提交中止"
exit 1
fi

3. 使用Git LFS管理大文件

# 安装Git LFS
git lfs install# 跟踪大文件类型
git lfs track "*.psd"
git lfs track "*.mp4"

完整工作流示例

# 开始新功能开发
git checkout main
git pull
git checkout -b feature/user-profile# 开发过程...
git add .
git commit -m "添加用户资料页面"
git push -u origin feature/user-profile# 合并到主分支
git checkout main
git pull
git merge feature/user-profile
git push# 清理分支
git branch -d feature/user-profile

通过这套流程,即使是完全的新手也能安全高效地管理项目代码。建议开始时先在一个测试项目上练习,熟悉后再应用到正式项目中。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/91324.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/91324.shtml
英文地址,请注明出处:http://en.pswp.cn/web/91324.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【AI】入门级提示词模板:适用于ChatGPT、文心一言等主流模型

入门级提示词模板:适用于 ChatGPT、文心一言等主流模型**在当下这个人工智能飞速发展的时代,ChatGPT、文心一言等主流大模型已经广泛地融入到我们的工作与生活当中。不管是创作文章、生成代码,还是进行数据分析、获取创意灵感,这些…

如何解决 undetected_chromedriver 启动慢问题

要解决 undetected_chromedriver 启动慢的问题,可以从以下几个方面优化配置和代码: 1. 指定本地 Chrome 二进制路径 避免自动搜索 Chrome 路径,直接指定位置: driver uc.Chrome(browser_executable_pathrC:\Program Files\Google…

Python 程序设计讲义(42):组合数据类型——元组类型:创建元组

Python 程序设计讲义(42):组合数据类型——元组类型:创建元组 目录Python 程序设计讲义(42):组合数据类型——元组类型:创建元组一、元组的特征二、创建元组1、使用圆括号&#xff0…

windows 设置 vscode 免密远程

我们可以使用 vscode ssh 进行远程编辑文件项目。也可以使用 ssh 密匙 来实现免密登录。 本人在本地windows系统有多个密匙,使用 D:\SPB_Data\.ssh\id_rsa_local 进行本地设备进行登录。 在 vscode ssh 配置文件中添加 IdentityFile 配置 Host 本地设备ipHostName …

ubuntu自动搭建Android平台NDK编译环境

sh setup_ndk_env.sh自动下载NDK并解压 提取Android平台工具链 验证Android工具链 设置工具链变量 export CROSS_TRIPLE=aarch64_linux_android export CROSS_ROOT=/home/ubuntu/${CROSS_TRIPLE} export ANDROID_NDK=${CROSS_ROOT} export AS=${CROSS_ROOT}/bin/llvm-as exp…

添加捕捉吸附标识(使用QT+OpenGL开发三维CAD)

捕捉吸附标识怎么画出来?在点吸附的时候能够展示吸附标识可以让用户更直观的看到当前捕捉点,从而更准确的进行设计和绘制。 效果视频见原文:添加捕捉吸附标识(使用QTOpenGL开发三维CAD) 16.Add snap label 鼠标捕捉吸…

元宇宙中的“虫洞“:技术实现、应用场景与未来挑战

一、技术定义与核心架构1.1 虫洞的元宇宙隐喻概念来源:虫洞在物理学中是连接不同时空的通道,而在元宇宙中,这一概念被引申为连接不同虚拟世界的跨平台协议。英伟达Omniverse平台通过USD(通用场景描述)实现了这一隐喻&a…

使用GIS中基于森林的分类与回归模型来估算房屋价值

“基于森林的分类与回归”,它可以帮助分析师有效地设计、测试和部署预测模型。 基于森林的分类与回归应用了 Leo Breiman 的随机森林算法,这是一种用于分类和预测的流行监督机器学习方法。该工具允许分析师轻松整合表格属性、基于距离的要素和解释栅格来…

《 java 随想录》| LeetCode链表高频考题

前言:这是专门针对java语言讲解的算法解析(题目顺序大致参考《代码随想录》)思维导图操作链表删除节点删除链表中 D 节点时,只需将其前驱节点 C 的 next 指针指向 D 的下一个节点 E。添加节点​先让 新节点 F 的 next 指针 指向 C…

学习嵌入式的第三十一天-数据结构-(2025.7.23)网络协议封装

今天的内容主要是网络协议以及常用工具的介绍。协议头与数据封包/拆包数据封包示例:MAC|IP|TCP|hello| ———————————— IP数据报IP头信息默认20字节常用网络测试工具telnetnetstatpingarpwiresharktcpdumpssh2secure crt工具安装命令sudo ufw disable sud…

STL学习(十、常用排序、拷贝、替换算法)

目录 一、常用排序算法 1.sort (1) 内置数据类型 (2)自定义数据类型 2. random_shuffle(iterator beg, iterator end) 3.merge 4.reverse 二、常用的拷贝和替换算法 1.copy(起始不如直接赋值) 2.replace 3.replace_if 4.swap 一、常用排序算法 1.sort 函数原型 s…

【Datawhale AI夏令营】科大讯飞AI大赛(大模型技术)/夏令营:让AI理解列车排期表(Task3)

我没招了jpgimport pandas as pd import requests import re import json from tqdm import tqdm from datetime import datetime, timedeltadef calculate_stop_duration(arrival_time_str, departure_time_str):"""计算列车停留时长,处理跨天和异常…

【前后端】node mock.js+json-server

JSON-Server 一个在前端本地运行,可以存储json数据的server。前端开发可以模拟服务端接口数据,在本地搭建一个JSON服务,自己产生测试数据。 使用npm全局安装json-server :npm install -g json-server可以通过查看版本号&#xff0…

疏老师-python训练营-Day30模块和库的导入

浙大疏锦行 知识点回顾: 导入官方库的三种手段导入自定义库/模块的方式导入库/模块的核心逻辑:找到根目录(python解释器的目录和终端的目录不一致) 作业:自己新建几个不同路径文件尝试下如何导入 一.学习知识点 DAY30 …

神经网络知识讨论

AI 核心任务与数据类型:特征提取核心:AI 的核心是从原始输入数据中提取特征,CV 是将图像数据转换为计算机可识别的特征,NLP 是将文本数据转换为特征,数据挖掘是将结构化数据转换为特征。数据类型特点:图像数…

kotlin类型可为空,进行空安全的区别

定义一个可为空的变量b(String?),默认没有?是不可以为空的 var b: String? "Kotlin" b null print(b) // 输出 null默认不可为空 var a: String "Kotlin" a null // 编译器报错,null 不能被赋给不为空的变量空安全调用&#x…

Mysql事务基础

事务是一个不可分割的数据库操作序列,也是数据库并发控制的基本单位,其执行的结果必须使数据库从一种一致性状态变到另一种一致性状态。事务是逻辑上的一组操作,要么都执行,要么都不执行 事务的特点 A(Atomicity&#…

FastAPI入门:安装、Pydantic、并发和并行

本系列参考FastAPI官方文档:https://fastapi.tiangolo.com/zh/python-types/安装 使用pip安装: pip install fastapi此外还需要 ASGI 服务器,生产环境可以使用 Uvicorn 或者 Hypercorn。 ASGI服务器:异步服务网关接口,…

欢乐的周末 - 华为OD统一考试(JavaScript 题解)

题目描述 小华和小为是很要好的朋友,他们约定周末一起吃饭。 通过手机交流,他们在地图上选择了多个聚餐地点(由于自然地形等原因,部分聚餐地点不可达)。 求小华和小为都能到达的聚餐地点有多少个? 输入描述 第一行输入m和n,m代表地图的长度,n代表地图的宽度 第二行…

算法竞赛阶段二-数据结构(38)数据结构动态链表list

动态链表(List)的基本概念动态链表是一种线性数据结构,通过节点间的指针连接实现动态内存分配。与数组不同,链表的大小可随需增减,插入和删除操作的时间复杂度为 O(1)(已知位置时),但…