git相关命令

一、前提安装

二、正常应用

三、详细命令

 

一、前提安装

  在系统中需要安装git, 安装教程可以看这:去看看

二、正常应用

  1.如果还没创建仓库

git init

  查看工作板状态

git status

  红色代表修改过和未添加的文件,将文件添加进去

git add .

  add 代表添加现在的文件到暂存区。 . 代表所有文件,如果是想添加所有js文件,就可以用 *.js 

   添加完成后再看看 git status,就会变成绿色

  如果想从暂存区删除,就可以用下面命令, 删除某一个文件就输入文件名

git reset .

  暂存区文件没问题后,就可以提交到本地仓库

git commit -m "first commit"

  commti 代表提交命令, -m 代表携带描述  “”里面的内容,就是你可以设置的描述内容,这些内容会跟推送到远程git仓库

  我这里是报错了,因为我还没有设置身份。

  这里就要用到, git config 了

git config –-local –-list

  config 代表设置命令, --local  代表查看本地配置,--global 代表查看全局配置  -- list 代表用列表方式将其展示出来。

   使用全局配置的时候可能会报错,没有该文件,设置后就会新建个文件

   使用下面命令可以配置用户信息

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

  再次查看就有信息了

   你可以设置在本地,也可以设置全局,如果本地没有用户信息,git 会去全局找信息,如果全局也没有,就会报上面的错。

  再次 commit就没报错了

  这时候,就可以将本地仓库提交到远程仓库

git push origin master

  push,代表推送, origin, 代表远程,  master, 代表主分支, masser

  我这里是再次报错,因为我还没设置远程地址。(这里是打错字了,origin少了i, 不过它同样会报错)

  远程仓库有很多,github,  gitee,都可以,我这里是gitee. 在新建仓库后可以看到仓库地址

  远程仓库有两种,一种是https, 一种是ssh, 还有其他两种不在这里讲述。

  先用https, ssh的方式请看后面单独讲,复制链接

  然后回到命令行

git remote add origin 远程地址

  回车后查看本地配置,就可以看到远程地址添加进去了

  然后再执行推送

  然后windows 版本就会弹出

  需要你输入账号密码,输入完成后,就可以推送了

   这里提示要先pull, 这个常见于编写代码后,没有先pull, 然后直接推送的情况,由于我们远程仓库是空的,这时候可以强制推送,覆盖远程

git push -f origin  master

  这就是推送成功了,去远程看看

 

  仓库已经有代码了。

 

  这是在本地推送代码到远程,那要是从远程下代码呢?

  2.从远程下代码

git clone git@github.com:git帐号名/仓库名.git

  使用常规的https的方式,那就需要输入账号密码

   输入该平台的账号密码就可以获取项目代码了,在当前文件夹下面就可以看见代码包了

  3.ssh方式。

  在windows,使用https 输入账号密码后,会保存,所以不用再次输入账号密码,但是在ubuntu等命令行操作时,就会在push和pull 反复需要输入账号密码,当配置好ssh后就可以不再输入账号密码

    3.1 windows

     在windows里面查看下密钥

     c盘--->用户--->自己的用户名---->ssh]下是否有id_rsa、id_rsa.pub文件,如果没有需要手动生成。

     在命令行输入,后面的邮箱得填入你的git账号邮箱,不然可能会ping不通。

ssh-keygen -t rsa -C "youremail@example.com"

    这里它会提示保存在哪个文件夹,如果需要单独放在一个地方,你可以修改地址,如果不用,直接回车

    这个是给密钥添加密码,第二次是确认密码,这里最好一路回车,不然连上后,还得输入这个密码。

    看到这个就是生成成功了,去文件夹看看,文件也出来了

    然后要读取公钥

cat /c/Users/Administrator/.ssh/id_rsa.pub

     复制里面的内容,到gitee个人设置里面去,找到ssh公钥

    将复制的内容放到公钥里面,在标题里起个名字,便于记忆管理。然后点击确定。输入密码就在远端装好ssh了。

    3.1.1测试下

     回到gitee项目下,复制gitee ssh地址

     回到本地命令行,修改远程地址

git remote set-url origin 复制的地址

     然后试试命令

git pull

    这里是第一连接gitee,提示你是否信任保存该地址的公钥。填入yes就好。

    然后返回的内容是在当前分支没有内容更新,所以已经通了。

    3.2 ubuntu

    在ubuntu是同样的命令,只是地址不一样,ubuntu密钥生成的地址是/home/用户名/.ssh/id_rsa

     如果远程没有分支,就先设置用户信息,添加源,然后add  commit 然后推送

    这样就成功了。

    3.3 pycharm 添加 .gitignore文件

     打开设置插件, 安装.ignore

    然后新建文件

    然后找到你需要对应的开发语言,这里用的python,所以点的python, 还可以多选。

    最后点击Generate 就可以生成了。

 三、详细命令

  以下内容来自参考: 去看看

  还有图文详细解释git工作原理,写得很好:去看看

1、第一次初始化

  • git init
    git add .
    git commit -m ‘first commit’
    git remote add origin git@github.com:帐号名/仓库名.git
    git pull origin master
    git push origin master # -f 强推
  • git clone git@github.com:git帐号名/仓库名.git

2、工作基本操作

  • git checkout master 切到主分支
  • git fetch origin 获取最新变更
  • git checkout -b dev origin/master 基于主分支创建dev分支
  • git add . 添加到缓存
  • git commit -m ‘xxx’ 提交到本地仓库
  • git fetch origin 获取最新变更

3、初始化仓库

git init

4、查看仓库当前状态

git status

5、文件相关操作

将文件添加到仓库:

  • git add 文件名 将工作区的某个文件添加到暂存区
  • git add . 将当前工作区的所有文件都加入暂存区
  • git add -u 添加所有被tracked文件中被修改或删除的文件信息到暂存区,不处理untracked的文件
  • git add -A 添加所有被tracked文件中被修改或删除的文件信息到暂存区,包括untracked的文件
  • git add -i 进入交互界面模式,按需添加文件到缓存区

将暂存区文件提交到本地仓库:

  • git commit -m “提交说明” 将暂存区内容提交到本地仓库
  • git commit -a -m “提交说明” 跳过缓存区操作,直接把工作区内容提交到本地仓库

比较文件异同

  • git diff 工作区与暂存区的差异
  • git diff 分支名 工作区与某分支的差异,远程分支这样写:remotes/origin/分支名
  • git diff HEAD 工作区与HEAD指针指向的内容差异
  • git diff 提交id 文件路径 工作区某文件当前版本与历史版本的差异
  • git diff –stage 工作区文件与上次提交的差异(1.6 版本前用 –cached)
  • git diff 版本TAG 查看从某个版本后都改动内容
  • git diff 分支A 分支B 比较从分支A和分支B的差异(也支持比较两个TAG)
  • git diff 分支A…分支B 比较两分支在分开后各自的改动

另外:如果只想统计哪些文件被改动,多少行被改动,可以添加 –stat 参数

6、查看历史记录

  • git log 查看所有commit记录(SHA-A校验和,作者名称,邮箱,提交时间,提交说明)
  • git log -p -次数 查看最近多少次的提交记录
  • git log –stat 简略显示每次提交的内容更改
  • git log –name-only 仅显示已修改的文件清单
  • git log –name-status 显示新增,修改,删除的文件清单
  • git log –oneline 让提交记录以精简的一行输出
  • git log –graph –all –online 图形展示分支的合并历史
  • git log –author=作者 查询作者的提交记录(和grep同时使用要加一个–all–match参数)
  • git log –grep=过滤信息 列出提交信息中包含过滤信息的提交记录
  • git log -S查询内容 和–grep类似,S和查询内容间没有空格
  • git log fileName 查看某文件的修改记录

7、代码回滚

  • git reset HEAD^ 恢复成上次提交的版本
  • git reset HEAD^^ 恢复成上上次提交的版本,就是多个^,以此类推或用~次数
  • git reflog
  • git reset –hard 版本号
  • –soft:只是改变HEAD指针指向,缓存区和工作区不变;
  • –mixed:修改HEAD指针指向,暂存区内容丢失,工作区不变;
  • –hard:修改HEAD指针指向,暂存区内容丢失,工作区恢复以前状态;

8、版本库相关操作

  • 删除版本库文件:git rm 文件名
  • 版本库里的版本替换工作区的版本:git checkout — test.txt

9、远程仓库相关操作

同步远程仓库:git push -u origin master

本地仓库内容推送到远程仓库:git remote add origin git@github.com:帐号名/仓库名.git

从远程仓库克隆项目到本地:git clone git@github.com:git帐号名/仓库名.git

查看远程库信息:git remote

拉取远程分支到本地仓库:

  • git checkout -b 本地分支 远程分支 # 会在本地新建分支,并自动切换到该分支
  • git fetch origin 远程分支:本地分支 # 会在本地新建分支,但不会自动切换,还需checkout
  • git branch –set-upstream 本地分支 远程分支 # 建立本地分支与远程分支的链接

同步远程仓库更新::git fetch origin master

10、分支相关操作

创建分支:git checkout -b dev -b表示创建并切换分支
上面一条命令相当于一面的二条:
git branch dev 创建分支
git checkout dev 切换分支

查看分支:git branch

合并分支:

  • git merge dev #用于合并指定分支到当前分支
  • git merge –no-ff -m “merge with no-ff” dev #加上–no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并

删除分支:git branch -d dev

查看分支合并图:git log –graph –pretty=oneline –abbrev-commit

11、git相关配置

安装完Git后第一件要做的事,设置用户信息(global可换成local在单独项目生效):

  • git config –global user.name “用户名” # 设置用户名
  • git config –global user.email “用户邮箱” #设置邮箱
  • git config –global user.name # 查看用户名是否配置成功
  • git config –global user.email # 查看邮箱是否配置

12、其他查看配置相关

  • git config –global –list # 查看全局设置相关参数列表
  • git config –local –list # 查看本地设置相关参数列表
  • git config –system –list # 查看系统配置参数列表
  • git config –list # 查看所有Git的配置(全局+本地+系统)
  • git config –global color.ui true //显示git相关颜色

13、撤消某次提交

  • git revert HEAD # 撤销最近的一个提交
  • git revert 版本号 # 撤销某次commit

14、标签

    • git tag 标签 //打标签命令,默认为HEAD
    • git tag //显示所有标签
    • git tag 标签 版本号 //给某个commit版本添加标签
    • git show 标签 //显示某个标签的详细信息

 四、 问题

    1. 清除git本地缓存和gitigore模板

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

     2. 放弃本地内容,强制覆盖

git fetch --all

git reset --hard origin/master 

git pull

 

 

  

posted @ 2023-05-18 15:08  PKGAME  阅读(22)  评论(0编辑  收藏  举报