git的常用命令有哪些
admin
2023-01-21 06:43:26
0

[TOC]

Git

配置

配置文件

以下配置中若出现相同配置项,根据顺序从下到上依次覆盖

级别命令配置文件
全局system/etc/gitconfig
用户global~/.gitconfig
项目local/etc/gitconfig

基本命令

  • 查看全局所有配置:git config --list --global
  • 查看某一项配置:git config user.name
  • 设置用户名:git config --global user.name 'yangqingjun'
  • 设置邮箱名:git config --global user.email 'yangqingjun001@hotmail.com'
  • 重置某项配置:git config --unset --global user.name
  • 添加别名:git config --global alias.co checkout

获取帮助

  • 获取某个命令帮助
    git help add
    git add --help
    man git-add
  • 获取所有命令名称:git help -a
  • 获取所有手册名称:git help -g

基本操作

获取 Git 仓库

空目录中初始化项目
  • 初始化新仓库命令:git init
  • 添加跟踪文件:git add LICENSE
  • 添加某类文件:git add *.c
  • 添加所有文件:git add .
克隆现有仓库

克隆仓库会将远程目标中所有分支、文件全部克隆下来

  • 克隆远程仓库:git clone https://github.com/libgit2/libgit2
  • 克隆远程仓库并重命名:git clone https://github.com/libgit2/libgit2 test

文件生命周期

  • 查看当前文件状态:git status
  • 追踪新文件:git add newfile
  • 状态简表:git status -s
符号说明文件所在区
??未追踪工作区
A_新追踪 未提交暂存区
AM新追踪 未提交 又修改暂存区、工作区
_M提交过 刚修改工作区
M_提交过 已暂存暂存区
MM提交过 暂存过 又修改暂存区、工作区

查看修改区别

  • 查看工作区和暂存区区别:git diff
  • 查看暂存区和提交区区别:git diff --staged

提交更改

  • 提交暂存区的内容:`git commit -m 'init'
  • 跳过暂存区直接提交:`git commit -am 'init'

移除文件

不追踪文件,删除文件
  • 删除之前未修改过:git rm test.txt
  • 删除之前已修改且提交到暂存区:git rm -f test.txt
不追踪文件,保留文件
  • 将已追踪的文件放弃追踪:git rm --cached test.txt
  • 在忽略文件中写入,用来放弃追踪

移动文件

git mv file1.txt file2.txt

不追踪的文件

配置文件

在根目录下的 .gitignore 文件中描述

全局配置
  • 全局配置命令:git config --global core.excludesfile ~/.gitignore
  • 全局忽略文件参考:https://github.com/yangqingjun/gitignore/blob/master/.gitignore
特定项目
  • 项目特定语言参考:https://github.com/yangqingjun/gitignore
匹配规则
  • 所有空行或者以 # 开头的行会被Git忽略
  • 以 / 开头防止递归。eg:/TODO 只忽略 TODO 文件,而不是文件夹
  • 以 / 结尾指定目录。eg:build/ 忽略 build/ 下所有文件
  • doc/*.txt 只忽略此目录下的
  • doc/*/.pdf 忽略doc目录下所有的
符号说明例子
*零或多个任意字符*.py doc/*.txt
**任意中间零个或多个目录a/**/z
?有且仅一个任意字符hello?.txt
[abc]方框内任意一个
[0-9]方框范围内任意一个
!追踪指定文件、忽略以上规则!index.py

分支操作

远程操作

GitHub

GitLab

图解

文件生命周期

git的常用命令有哪些

常用命令

  • add: 添加内容到暂存区;添加内容到下次提交中

参考

  • 安装Git参考:https://git-scm.com/book/zh/v2/起步-安装-Git
  • Linux各版本安装命令:https://git-scm.com/download/linux
  • 各编程语言忽略的文件参考:https://github.com/yangqingjun/gitignore

其他配置

全局颜色 git config --global color.ui true

查个mac快捷键 命令行输入 打开finder
open .

查看区别-工作目录与暂存区

git diff index.html

查看区别 工作目录与提交完成的

git diff --staged

删除不追踪的文件

git rm style.css

修改文件名

git mv file1 file2

删除文件

git rm file1

恢复删除文件,最近一次提交

目前还在工作区,未提交状态
git checkout HEAD -- index.html
已经提交
git checkout HEAD^ -- index.html

查看日志,一行
git log --oneline

恢复提交
git revert fsdgj

控制指针位置
git reset fsdgj
--soft 软重置,不影响工作区和暂存区
--hart 工作区和暂存区都重置
--mixed 默认的 只重置暂存区

git stash save '放到工作进度里'
显示工作进度列表
git stash list
查看区别
git stash show -p stash@{0}
恢复进度
git stash apply stash@{0}
删除进度
git stash drop stash@{0}
git stash pop stash@{0}

日志
查看最近5条
git log --oneline -5
查看某个作者提交的
git log --oneline --author="yangqingjun"
所有包含 index 的提交
git log --oneline --grep='index'
某个日期之前的提交
git log --oneline --before='2019-01-01'
三天前的
--before='3 days'
图形界面查看
git log --oneline --graph

分支
查看当前分支
git status
查看所有分支
git branch
创建分支
git branch mobile-feature
切换分支
git checkout mobile-feature

显示分支的提交
git log --oneline --decorate

显示所有分支提交详情
git log --oneline --decorate --all

对比两个分支区别
git diff master..mobile-feature  后面可以加上文件名

合并分支
在master分支上
git merge mobile-feature

相关内容

热门资讯

今日重大通报“三鑫联盟.开挂器... 有 亲,根据资深记者爆料三鑫联盟是可以开挂的,确实有挂(咨询软件无需打开...
今日重大发现“数独大赛.到底是... 有 亲,根据资深记者爆料数独大赛是可以开挂的,确实有挂(咨询软件无需打开...
【今日要闻】“掌中乐游戏中心.... 【今日要闻】“掌中乐游戏中心.是不是有挂?”透视曝光猫腻您好,掌中乐游戏中心这个游戏其实有挂的,确实...
今日重大消息“新大圣牛牛.辅助... 您好:新大圣牛牛这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游...
【今日要闻】“皇豪互娱牛牛.开... 家人们!今天小编来为大家解答皇豪互娱牛牛透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里...
今日重大通报“聚友互娱.是不是... 您好:聚友互娱这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游戏...
原创 从... 哈喽大家好,今天小无带大家聊聊最近在WAIC2025上爆火的国产双臂协作机器人。 这台机器可不只是个...
今日重大通报“经典联盟牛牛.究... 有 亲,根据资深记者爆料经典联盟牛牛是可以开挂的,确实有挂(咨询软件无需...
【专家观点】加快推进人工智能技... 党中央、国务院高度重视人工智能技术在医疗卫生场景培育和应用。2024年11月,国家卫健委等三部门联合...
【第一消息】“炫龙牛牛.有挂吗... 有 亲,根据资深记者爆料炫龙牛牛是可以开挂的,确实有挂(咨询软件无需打开...