【linux命令讲解大全】014.Git:分布式版本控制系统的先驱和常用命令清单(三)

文章目录

    • 查看某个文件历史
    • 打造自己的git命令
    • 中文乱码的解决方案
    • 新建仓库
      • 初始化
      • 获取状态
      • 添加
      • 提交更新
      • 远程
      • 推送
      • 克隆
    • 本地操作
      • 获取帮助信息
      • 添加
      • 移除文件
      • 查看提交记录
      • 提交更新
      • 撤销更新
      • 撤销操作
      • 切换分支和恢复文件
      • 查看差异
      • 储藏现场
    • 合并
      • 普通合并
      • 拣选合并
      • 变基
  • 从零学 `python`

查看某个文件历史

  • git log --pretty=oneline 文件名:列出文件的所有改动历史
  • git show c178bf49:某次的改动的修改记录
  • git log -p c178bf49:某次的改动的修改记录
  • git blame 文件名:显示文件的每一行是在那个版本最后修改。
  • git whatchanged 文件名:显示某个文件的每个版本提交信息:提交日期,提交人员,版本号,提交备注(没有修改细节)

打造自己的git命令

git config --global alias.st status
git config --global alias.br branch
git config --global alias.co checkout
git config --global alias.ci commit

配置好后再输入git命令的时候就不用再输入一大段了,例如我们要查看状态,只需输入:

git st

中文乱码的解决方案

git config --global core.quotepath false

新建仓库

初始化

git init

获取状态

git status

添加

git add file  # .或*代表全部添加
git rm --cached   # 在commit之前撤销git add操作
git reset head  # 比上面更方便的方法

提交更新

git commit -m "message"  #此处注意乱码

远程

git remote add origin [email protected]:JSLite/test.git  # 添加源

推送

git push -u origin master  # push同时设置默认跟踪分支
git push origin master
git push -f origin master  # 强制推送文件,缩写-f(全写--force)

克隆

git clone git://github.com/JSLite/JSLite.js.git
git clone git://github.com/JSLite/JSLite.js.git mypro  # 克隆到自定义文件夹
git clone [user@]example.com:path/to/repo.git/  # SSH协议还有另一种写法。

git clone支持多种协议,除了HTTP(s)以外,还支持SSH、Git、本地文件协议等,下面是一些例子。git clone <版本库的网址> <本地目录名>
$ git clone http[s]://example.com/path/to/repo.git/
$ git clone ssh://example.com/path/to/repo.git/
$ git clone git://example.com/path/to/repo.git/
$ git clone /opt/git/project.git 
$ git clone file:///opt/git/project.git
$ git clone ftp[s]://example.com/path/to/repo.git/
$ git clone rsync://example.com/path/to/repo.git/

本地操作

获取帮助信息

git help config

添加

git add *  # 跟踪新文件
git add -u [path]  # 添加[指定路径下]已跟踪文件

移除文件

rm * & git rm *  # 移除文件
git rm -f *  # 移除文件
git rm --cached *  # 取消跟踪
git mv file_from file_to  # 重命名跟踪文件

查看提交记录

git log  # 查看提交记录

提交更新

git commit  # 提交更新
git commit -m 'message'  # 提交说明
git commit -a  # 跳过使用暂存区域,把所有已经跟踪过的文件暂存起来一并提交
git commit --amend  # 修改最后一次提交
git commit log  # 查看所有提交,包括没有push的commit
git commit -m "#133"  # 关联issue,任意位置带上#符号加上issue号码
git commit -m "fix #133"  # commit关闭issue
git commit -m '概要描述'$'\n\n''1.详细描述'$'\n''2.详细描述'  # 提交简要描述和详细描述

撤销更新

git reset HEAD *  # 取消已经暂存的文件
git reset --mixed HEAD *  # 同上
git reset --soft HEAD *  # 重置到指定状态,不会修改索引区和工作树
git reset --hard HEAD *  # 重置到指定状态,会修改索引区和工作树
git reset -- files *  # 重置index区文件

撤销操作

git revert HEAD  # 撤销前一次操作
git revert HEAD~  # 撤销前前一次操作
git revert commit  # 撤销指定操作

切换分支和恢复文件

git checkout -- file  # 取消对文件的修改(从暂存区——覆盖worktree file)
git checkout branch|tag|commit -- file_name  # 从仓库取出file覆盖当前分支
git checkout HEAD~1 [文件]  # 将会更新working directory去匹配某次commit
git checkout -- .  # 从暂存区取出文件覆盖工作区
git checkout -b gh-pages 0c304c9  # 这个表示从当前分支commit哈希值为0c304c9的节点,分一个新的分支gh-pages出来,并切换到gh-pages

查看差异

git diff file  # 查看指定文件的差异
git diff --stat  # 查看简单的diff结果
git diff  # 比较Worktree和Index之间的差异
git diff --cached  # 比较Index和HEAD之间的差异
git diff HEAD  # 比较Worktree和HEAD之间的差异
git diff branch  # 比较Worktree和branch之间的差异
git diff branch1 branch2  # 比较两次分支之间的差异
git diff commit commit  # 比较两次提交之间的差异
git diff master..test  # 上面这条命令只显示两个分支间的差异
git diff master...test  # 你想找出'master'、'test'的共有父分支和'test'分支之间的差异,你用3个'.'来取代前面的两个'.'

储藏现场

git stash  # 将工作区现场(已跟踪文件)储藏起来,等以后恢复后继续工作。
git stash list  # 查看保存的工作现场
git stash apply  # 恢复工作现场
git stash drop  # 删除stash内容
git stash pop  # 恢复的同时直接删除stash内容
git stash apply stash@{0}  # 恢复指定的工作现场,当你保存了不止一份工作现场时。

合并

普通合并

git merge --squash test  # 合并压缩,将test上的commit压缩为一条

拣选合并

git cherry-pick commit  # 拣选合并,将commit合并到当前分支
git cherry-pick -n commit  # 拣选多个提交,合并完后可以继续拣选下一个提交

变基

git rebase master  # 将master分之上超前的提交,变基到当前分支
git rebase --onto master 169a6  # 限制回滚范围,rebase当前分支从169a6以后的提交
git rebase --interactive  # 交互模式,修改commit
git rebase --continue  # 处理完冲突继续合并
git rebase --skip  # 跳过
git rebase --abort  # 取消合并

从零学 python

【从零学习python 】92.使用Python的requests库发送HTTP请求和处理响应
【从零学习python 】91. 使用装饰器和字典管理请求路径的简洁Web应用
【从零学习python 】93.使用字典管理请求路径
【从零学习python 】89. 使用WSGI搭建简单高效的Web服务器
【从零学习python 】88. WSGI接口详解:实现简单高效的Web开发
【从零学习python 】87. 手动搭建HTTP服务器的Python实现及多线程并发处理
【从零学习python 】86. 深入了解HTTP协议及其在浏览器和服务器通信中的作用
【从零学习python 】85.Python进程池的并行计算技术应用
【从零学习python 】84.深入理解线程和进程
【从零学习python 】83. Python多进程编程与进程池的使用
【从零学习python 】82. 基于多线程的聊天程序实现
【从零学习python 】81.Python多线程通信与队列的应用
【从零学习python 】80.线程访问全局变量与线程安全问题
【从零学习python 】79. 线程访问全局变量与线程安全问题
【从零学习python 】78. 文件下载案例
【从零学习python 】77. TCP服务端编程及注意事项
【从零学习python 】76.服务器与客户端:网络通信的关键组成部分
【从零学习python 】75. TCP协议:可靠的面向连接的传输层通信协议
【从零学习python 】74. UDP网络程序:端口问题与绑定信息详解
【从零学习python 】73. UDP网络程序-发送数据
【从零学习python 】72. 深入理解Socket通信及创建套接字的方法
【从零学习python 】71. 网络端口及其作用
【从零学习python 】70.网络通信方式及其应用:从直接通信到路由器连接多个网络
【从零学习python 】69. 网络通信及IP地址分类解析
【从零学习python 】68. Python正则表达式中的贪婪和非贪婪模式
【从零学习python 】67.Python中的re模块:正则替换与高级匹配技术
【从零学习python 】66.深入了解正则表达式:模式匹配与文本处理的利器
【从零学习python 】65. Python正则表达式修饰符及其应用详解
【从零学习python 】64. Python正则表达式中re.compile方法的使用详解
【从零学习python 】63.正则表达式中的re.Match类及其属性和方法介绍
【从零学习python 】62. Python正则表达式:强大的字符串匹配工具
【从零学习python 】61.Python中的property属性详解和应用示例
【从零学习python 】60.探索生成器:迭代的灵活利器
【从零学习python 】59.迭代器:优化数据遍历的高效工具
【从零学习python 】58.Python中的自定义异常及引发异常的方法
【从零学习python 】57.Python中使用with关键字正确关闭资源
【从零学习python 】56. 异常处理在程序设计中的重要性与应用
【从零学习python 】55.Python中的序列化和反序列化,JSON与pickle模块的应用
【从零学习python 】54. 内存中写入数据
【从零学习python 】53. CSV文件和Python的CSV模块
【从零学习python 】52.文件的读写 - Python文件操作指南
【从零学习python 】51.文件的打开与关闭及其在Python中的应用
【从零学习python 】49. Python中对象相关的内置函数及其用法
【从零学习python 】48.Python中的继承与多继承详解
【从零学习python 】47. 面向对象编程中的继承概念及基本使用
【从零学习python 】46. Python中的__new__和__init__方法解析及单例设计模式
【从零学习python 】45.Python中的类方法和静态方法
【从零学习python 】44.面向对象编程中的私有属性和方法
【从零学习python 】43. Python面向对象编程中的实例属性和类属性
【从零学习python 】42.Python中的内置属性和方法
【从零学习python 】41.python魔法方法(二)
【从零学习python 】40.python魔法方法(一)
【从零学习python 】39.面向对象基本语法及应用示例
【从零学习python 】38.Python包的使用及导入方式
【从零学习python 】37.Python自定义模块的使用和注意事项
【从零学习python 】36.Python中使用pip进行第三方包管理的方法与技巧
【从零学习python 】35. Python常见系统模块及其用法
【从零学习python 】34.Python模块的导入和使用方法详解
【从零学习python 】33.装饰器的作用(二)
【从零学习python 】32.装饰器的作用(一)
【从零学习python 】31.深入理解Python中的高阶函数和闭包
【从零学习python 】30.深入理解递归函数和匿名函数
【从零学习python 】29. 「函数参数详解」——了解Python函数参数的不同用法
【从零学习python 】28. Python中的局部变量和全局变量
【从零学习python 】27. Python 函数的使用及嵌套调用
【从零学习python 】25.函数:提高代码编写效率的利器
【从零学习python 】24. Python中的字符串操作与遍历方法
【从零学习python 】23. Python中集合(set)的使用方法和常见操作
【从零学习python 】22. Python中的字典的增删改查及字典的变量
【从零学习python 】21.Python中的元组与字典
【从零学习python 】20. Python列表操作技巧及实例
【从零学习python 】19. 循环遍历列表和列表嵌套的应用
【从零学习python 】18. Python列表的基本操作详解(一)
【从零学习python 】17. Python字符串的format方法(二)
【从零学习python 】16. Python字符串的format方法(一)
【从零学习python 】15.深入了解字符串及字符集编码
【从零学习python 】14.Python字符串常见操作(二)
【从零学习python 】13.Python字符串常见操作(一)
【从零学习python 】12.Python字符串操作与应用
【从零学习python 】11.Python循环语句和控制流程
【从零学习python 】10.Python条件语句和if嵌套详解
【从零学习python 】09.Python 中的条件判断语句
【从零学习python 】08.Python了解位运算符, 运算符优先级
【从零学习python 】07.Python运算符详解:赋值、比较和逻辑运算符
【从零学习python 】06. Python中运用算数运算符进行计算和字符串拼接
【从零学习python 】05. Python中的输出和输入
【从零学习python 】04. Python编程基础:变量、数据类型与标识符
【从零学习python 】03. Python交互式编程及注释详解
【从零学习python 】02. 开发工具介绍
【从零学习python 】01. 安装配置python

你可能感兴趣的:(linux命令大全,linux,分布式,版本控制,Git命令,分支管理,提交记录,差异比较)