全方位入门git学习笔记
基础操作
上传 git commit -m "填写便签"
查看改动的文件 git status
查看上传历史 git log
查看单个人的上传历史 git log --author="xxx"
配置邮箱和用户名
配置用户名 git config --global user.name "xxx" //global是全局的意思,本地可改为local
配置邮箱 git config --global user.email "xxx"
查看配置信息 git config --global --list
文件增加、删除、修改和查看
添加一个文件,git add "文件名" 并且要commit
删除一个文件,git rm "文件名" (也可以直接删除文件) 然后git add . 并commit
重命名文件 git mv 改动前 改动后 (也可以手动改名然后git add 更改后文件名, git rm更改前文件)并commit
移动文件到文件夹,可以使用 git mv 文件 目标文件夹/新名字 //也可以不改名
查看文件变化 git log --pretty=oneline 文件名 //能看到commit 内容及id
根据commit id查commit内容 git show commitid
查看文件内容变化 git log -p 文件名
查看更改前后 git diff //后面也可以指定文件名查单个文件
文件还原
将文件还原上次commit状态 git checkout -- 文件名 //防误操作,已经add到缓存区就不能用了
将文件撤销追踪(从缓存区拿出)git reset HEAD 文件名
将项目还原到上版本 git reset --hard HEAD^ //一个^就是一个版本
将项目还原到指定commitid版本 git reset --hard commitid //commit根据git log查看
将文件还原到指定版本 git checkout commitid -- 文件名
将项目推送到远程仓库 git push origin master
标签
- 创建标签 git tag 标签名 commitid //不加commitid 默认加在最后一次commit上
- 查看所有标签 git tag
- 删除标签 git tag -d 标签名
- 将tag推送至远程仓库 git push origin 标签名
分支
分支基本操作
- 创建分支 git branch 分支名
- 查看分支 git branch
- 切换分支 git checkout 分支名
- 删除分支 git branch -d 分支名 //有commit的分支不能直接删除,可以将d改成D进行强制删除
- 创建并切换到新分支 git checkout -b 分支名
分支合并
合并分支代码 get merge 指定分支名 合并指定分支到当前分支
合并时冲突
1.方法一:直接忽略其他分支并保留当前分支代码 git merge --abort 或手动改代码,再git add . ;git commit 输入注释报存,再commit提交就好了
2.方法二:修改代码 git add .然后输入git commit然后输入描述,再点ESC,再输入:wq ,然后git commit -m xxx,最后git push就好了
分支版本和远程分支操作
简写方式查看提交记录 git log --oneline
查看版本路线 git log --oneline --graph
拉取远程分支 git fetch
查看远程分支 git branch -av
删除远程分支 git push origin --delete 分支名
push时的代码冲突解决
不同人修改不同文件,已经push,当push时可能会报错,
- 需要 git branch -av查看修改的文件
- 复制remotes后面的路径(remotes/origin/xxx)
- 再合并 git merge origin/test 输入信息保存后,就可以正常push了
不同人修改相同分支的相同文件代码
先拉取远程分支代码,再push;直接push,可能会冲突
拉取代码到本地 git clone 代码地址
本地分支与原程分支做关联 git checkout 分支名 远端分支地址(/remotes/origin/test)
GitHub插件
谷歌访问助手; Octotree(提供目录结构); Enhanced GitHub(显示单个文件大小及下载单个文件);gitzip for github(双击空白区即可下载单个文件夹)