GIT常用操作指令

创建一个GIT项目的过程

$ makdir ~/hello-world    //创建一个项目hello-world
$ cd ~/hello-world       //打开这个项目
$ git init             //初始化 
$ touch README
$ git add README        //更新README文件
$ git commit -m 'first commit'     //提交更新,并注释信息“first commit” 
$ git remote add origin git@github.com:...     //连接远程github项目  
$ git push -u origin master     //将本地项目更新到github项目上去

删除本地仓库:

rm -rf .git

忽略规则

新建.gitignore文件。

# 此为注释 – 将被 Git 忽略

*.a       # 忽略所有 .a 结尾的文件
!lib.a    # 但 lib.a 除外
/TODO     # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/    # 忽略 build/ 目录下的所有文件
doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt

.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。那么解决方法就是先把本地缓存删除(改变成未track状态),然后再提交。

git rm -r --cached .
git add .
git commit -m 'update .gitignore'

添加远程github仓库

先删除远程 git 仓库

$ git remote rm origin

再添加远程 Git 仓库

$ git remote add origin http:...

1.执行 git remote rm origin 报错:

fatal: remote origin already exists.

,我们可以手动修改gitconfig文件的内容
,找到你的github的安装路径,如C:\Users\ASUS\AppData\Local\GitHub\...
,把里面的[remote "origin"]那一行删掉就好了!

2.执行 git remote rm origin 报错:

error:failed to push som refs to

解决办法如下:

$ git pull origin master //先把远程服务器github上面的文件拉下来
$ git push origin master

如果出现报错

fatal: Couldn't find remote ref master或者fatal: 'origin' does not appear to be a git repository以及fatal: Could not read from remote repository.

需要重新输入

$ git remote add origin git@github.com:djqiang/gitdemo.git

gitconfig配置文件

Git有一个工具被称为git config,它允许你获得和设置配置变量;这些变量可以控制Git的外观和操作的各个方面。这些变量可以被存储在三个不同的位置:
1./etc/gitconfig 文件:包含了适用于系统所有用户和所有库的值。如果你传递参数选项’–system’ 给 git config,它将明确的读和写这个文件。
2.~/.gitconfig 文件 :具体到你的用户。你可以通过传递–global 选项使Git 读或写这个特定的文件。
3.位于git目录的config文件 (也就是 .git/config) :无论你当前在用的库是什么,特定指向该单一的库。每个级别重写前一个级别的值。因此,在.git/config中的值覆盖了在/etc/gitconfig中的同一个值。
在Windows系统中,Git在$HOME目录中查找.gitconfig文件(对大多数人来说,位于C:\Documents and Settings\$USER下)。它也会查找/etc/gitconfig,尽管它是相对于Msys 根目录的。这可能是你在Windows中运行安装程序时决定安装Git的任何地方。

当你安装Git后首先要做的事情是设置你的用户名称和e-mail地址。这是非常重要的,因为每次Git提交都会使用该信息。它被永远的嵌入到了你的提交中:

$ git config --global user.name "John Doe"
$ git config --global user.email johndoe@example.com

如果你想检查你的设置,你可以使用 git config –list 命令来列出Git可以在该处找到的所有的设置:

$ git config --list

你也可以查看Git认为的一个特定的关键字目前的值,使用如下命令 git config {key}:

$ git config user.name

放弃修改

git checkout . #本地所有修改的。没有的提交的,都返回到原来的状态
git stash #把所有没有提交的修改暂存到stash里面。可用git stash pop回复。
git reset --hard HASH #返回到某个节点,不保留修改。
git reset --soft HASH #返回到某个节点。保留修改

git clean -df #返回到某个节点
git clean 参数
    -n 显示 将要 删除的 文件 和  目录
    -f 删除 文件
    -df 删除 文件 和 目录

可以使用:

git checkout . && git clean -xdf




参考文献:

github常见操作和常见错误

<think>好的,我需要回答用户关于Git常用指令的问题。首先,我得回忆一下自己常用Git命令,确保没有遗漏重要的部分。用户可能刚开始接触Git,所以需要从基础开始介绍,结构要清晰。 首先,我应该分几个主要类别来组织这些命令,比如仓库创建与克隆、基础操作、分支管理、远程仓库、撤销与恢复、查看信息等。这样用户查找起来更方便。 接下来,每个类别下要列出最常用指令。例如,初始化仓库的git init和克隆仓库的git clone。然后添加、提交文件的git add和git commit。分支部分要包括创建、切换、合并和删除分支的命令,比如git branch、git checkout、git merge这些。远程仓库相关的git remotegit push、git pull也不能少。 还要考虑用户可能遇到的撤销更改的情况,所以需要包含git checkout -- <file>、git reset之类的命令。查看状态和日志的git status、git log也是必不可少的。 需要检查每个命令的正确性,确保语法和参数没有错误。比如git commit -m后面的消息要用引号包裹,合并分支时的git merge <branch>是否正确。另外,是否漏掉了git fetch或者git stash这些有用的指令? 可能用户还需要一些进阶命令的提示,比如标签管理git tag,或者储藏修改git stash,但用户主要问的是常用指令,所以先集中在基础部分。最后加上一些总结性的提示,比如推荐学习资源,或者建议用户多练习。这样应该能覆盖大部分常见的使用场景,帮助用户快速掌握Git的基本操作。</think>以下是 Git 常用指令的整理说明,按使用场景分类: --- ### 一、仓库创建与克隆 1. `git init` 在当前目录初始化新仓库(创建 .git 目录) 2. `git clone <url>` 克隆远程仓库到本地(如 `git clone https://github.com/user/repo.git`) --- ### 二、基础操作 1. `git add <file>` 将文件添加到暂存区(`git add .` 添加所有修改) 2. `git commit -m "提交说明"` 提交暂存区内容到本地仓库 3. `git status` 查看工作区和暂存区状态 --- ### 三、分支管理 1. `git branch` 查看本地分支列表(`git branch -a` 查看所有分支,含远程) 2. `git branch <分支名>` 创建新分支 3. `git checkout <分支名>` 切换到指定分支(`git checkout -b <新分支名>` 创建并切换) 4. `git merge <分支名>` 将指定分支合并到当前分支 5. `git branch -d <分支名>` 删除本地分支 --- ### 四、远程仓库操作 1. `git remote add <远程名> <url>` 添加远程仓库(如 `git remote add origin https://...`) 2. `git push <远程名> <分支名>` 推送本地提交到远程(如 `git push origin main`) 3. `git pull <远程名> <分支名>` 远程更新并合并到本地 4. `git fetch <远程名>` 仅下载远程更新但不合并 --- ### 五、撤销与恢复 1. `git restore -- <file>` 丢弃工作区修改(Git 2.23+,替代旧版 `git checkout -- <file>`) 2. `git reset HEAD <file>` 将文件移出暂存区(撤销 `git add` 操作) 3. `git commit --amend` 修改最后一次提交(可修改提交信息或添加遗漏文件) --- ### 六、查看信息 1. `git log` 查看提交历史(`git log --oneline` 简化显示) 2. `git diff` 查看工作区与暂存区的差异 3. `git show <commit-id>` 查看某次提交的详细内容 --- ### 高频使用场景示例 1. **日常提交代码** ```bash git add . git commit -m "fix: 修复登录按钮样式" git push origin main ``` 2. **合并分支** ```bash git checkout main git merge feature/login ``` 3. **同步远程更新** ```bash git pull origin main ``` --- ### 学习建议 1. 使用 `git help <命令>` 查看具体命令帮助文档 2. 推荐图形化工具辅助理解:GitKraken、SourceTree、VS Code 内置 Git 3. 掌握 `.gitignore` 文件配置(排除无需版本控制的文件) > 注意:部分命令行为在不同 Git 版本中可能有差异(如 `git restore` 替代旧命令),建议使用 Git 2.23+ 版本。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值