[oeasy]python0145_版本控制_git_备份还原

简介: [oeasy]python0145_版本控制_git_备份还原

git版本控制 回忆上次内容

  • 上次我们了解了 try 的完全体
  • try
  • 尝试运行


  • except
  • 发现异常时运行的代码块


  • else
  • 没有发现异常时运行的代码块


  • finally
  • 无论是否发现异常最终都要运行的代码块



添加图片注释,不超过 140 字(可选)

  • 发现导入部分
  • 可以再分为两个子模块
  • 一个输入 a
  • 一个输入 b


  • 可以再拆分么?🤔

观察结构

  • 这是test目录目前的结构

添加图片注释,不超过 140 字(可选)

  • 想把get_fruits.py再拆成两个
  • get_apples.py   - 输入apple数量
  • get_bananas.py   - 输入banana数量


尝试保存版本

  • 再继续之前
  • 先把 目前的test目录 备份起来


  • 使用 git 进行版本控制

# 先进入test cd test # 观察位置 pwd # 初始化 git init #把目前apple文件夹下所有的都备份 git add . # 备份 git commit

  • commit 遇到问题
  • 你是谁的问题


问题

添加图片注释,不超过 140 字(可选)

  • 提示需要用户名和邮箱
  • 因为工程可能是个多人合作的
  • 需要知道提交是谁做的


  • 如何设置用户名和邮箱呢?

第一次提交

  • 按提示录入邮箱和用户名
  • 这邮箱和用户名
  • 不一定是注册过的


  • 只是一个标记


添加图片注释,不超过 140 字(可选)

  • 然后git commit
  • 第一次 提交


第一次提交的注释

  • 终端会自动打开vim
  • 要求对提交做注释
  • 没有具体的要求
  • 写点什么提示之类的就行
  • 完成后:wq
  • 退出


添加图片注释,不超过 140 字(可选)

  • 这就把 代码目前的这个状态
  • 备份下来了


  • 这是 第一次提交

查看版本 #查看提交版本的日志 git log

  • 目前有一个提交 commit

添加图片注释,不超过 140 字(可选)

开始修改

  • 在test目录下
  • 新建get_apples.py


添加图片注释,不超过 140 字(可选)

  • :r get_fruits.py
  • 读取get_fruits.py
  • 到当前文件缓存


最终效果

添加图片注释,不超过 140 字(可选)

  • 把输入模块再拆分
  • 输入 apple数量 、get_apples.py
  • 输入 banana数量 、get_bananas.py


  • 调整输入函数
  • 这样可以运行么?

尝试运行

添加图片注释,不超过 140 字(可选)

  • 试验成功!
  • 可以正确执行


  • 但是这么写是有问题的!
  • 为什么?
  • 因为它不符合禅意


  • 啊?😲

zen 禅

  • Flat is better than nested.
  • 扁平胜于嵌套


  • 现在的控制结构:
  • 中控 main
  • 输入 get_fruits
  • 输入 a
  • get_apples


  • 输入 b
  • get_bananas



  • 处理 process
  • 输出 outprint


  • 结构太多出现了三层

添加图片注释,不超过 140 字(可选)

  • 好的程序是
  • 并排很多的
  • 而串起来的并不深


  • 高内聚
  • 低耦合



过度抽象

  • 没有必要嵌套成三层
  • 我们应该更多使用扁平


  • 两层能轻松解决的
  • 别弄到三层


  • tcp/ip 四层就能搞定的事
  • osi 非要搞到七层,一定不好做


  • 层与层之间的接口是很容易固化的
  • 这不是教条
  • 而是实际开发中的经验


  • 你见过那种层层传递过程中的繁琐和损耗么?
  • 想回滚到初始状态(init)


  • 还好做了版本控制

第二次提交

  • 先把当前的这个修改提交了

git add . git commit git log

  • 提交新Commit

添加图片注释,不超过 140 字(可选)

  • 系统还是会自动开vim来记录本版本的注释
  • :wq就可以保存注释

添加图片注释,不超过 140 字(可选)

  • 完成第二次提交

查看两次提交

  • git log

添加图片注释,不超过 140 字(可选)

  • 我们可以看到有两次提交
  • 第一次
  • 红框以内
  • 提交信息为 init
  • 特征码为 3153a6e...


  • 第二次
  • 黄框以内
  • 提交信息为 add two python files
  • 特征码为 1f6de17...



回滚 #查看commit提交的简写形式 git log --pretty=format:"%h - %an, %ar : %s" #签出原来的提交 git checkout 第一次提交的特征码...

添加图片注释,不超过 140 字(可选)

  • 然后再签出老的那个
  • 3153a6e


前后对比

添加图片注释,不超过 140 字(可选)

  • 硬盘回到初始状态了
  • 新保留的分支 就不要了


  • git 就是这样的 版本控制软件
  • 可以恢复到
  • 任何 commit 过的时间点
  • 甚至是
  • 任何人 在任何时间点 commit 过的版本



  • 仿佛一个时光机


  • 在不同时间和不同人提交的版本间穿梭
  • 这次 为什么要 回到过去?
  • 这次回去的 原因 是
  • 扁平胜于嵌套



复杂

  • 多余的层级
  • 是 繁琐的


  • 奢华繁复
  • 是 堕落的开始


添加图片注释,不超过 140 字(可选)

  • 追求 美之为美
  • 孔雀为了美
  • 进化到了什么样子
  • 尾大不掉



  • 这种美并不符合
  • 客观规律


  • 繁文冗节只会造成辞藻的堆砌
  • 陷入到文字割裂的离散世界中去
  • 可世界本是连续的


  • 真善美中
  • 真 排第一


美之为美

  • 凡尔赛和圆明园
  • 都不是 励精图治的审美


添加图片注释,不超过 140 字(可选)

  • 金玉其外
  • 败絮其中
  • 金玉满堂
  • 莫之能守
  • 什么是能够自强的审美呢

简单

  • 断舍离
  • 枯山水
  • 说的都是化缘


  • 为道日损,损之又损,以至于无为
  • 无为而无不为


添加图片注释,不超过 140 字(可选)

  • 致虚极守静笃
  • 为的是蓄势待发


添加图片注释,不超过 140 字(可选)

  • 静观其变
  • 要留白 才能作画


  • 代码的演化 本身就是一种涅槃
  • 消珥过去的自己
  • 在迭代中获得新的生命


无为

  • 为无为
  • 才能 全面观察和蓄力


  • 味无味
  • 才能 有敏感的味觉


  • 事无事
  • 才能 有机敏的反应


添加图片注释,不超过 140 字(可选)

  • 静下来 品味
  • 禅茶一味
  • 感觉是一致的


一致

  • Explicit is better than implicit.
  • 明了胜于晦涩(优美的代码应当是明了的,命名规范,风格相似)


  • Simple is better than complex.
  • 简洁胜于复杂(优美的代码应当是简洁的,不要有复杂的内部实现)


  • Complex is better than complicated.
  • 复杂胜于凌乱(如果复杂不可避免,那代码间也不能有难懂的关系,要保持接口简洁)


  • Flat is better than nested.
  • 扁平胜于嵌套(优美的代码应当是扁平的,不能有太多的嵌套)


  • 以上说的都是一回事:
  • 简单而且明确!
  • 形成了上面的观念就会发现代码的美与丑
  • 代码的审美来自于以上的判断


添加图片注释,不超过 140 字(可选)

  • Beautiful is better than ugly.
  • 优美胜于丑陋(Python 以编写优美的代码为目标)


  • 审美僵化是 可怕的
  • 保持 简单 且 明确
  • 就可以保持 天真的状态


总结

  • 使用了版本控制 git
  • 制作备份
  • 进行回滚


  • 尝试了 嵌套的控制结构
  • 层层 控制
  • 不过 非到不得以
  • 尽量不要 太多层次的嵌套
  • 虽然这样 从顶到底
  • 含义 明确


  • 扁平 难道就不能
  • 含义明确么?


  • 还可以 做点什么?
  • 让程序更加明确呢?🤔



目录
相关文章
|
9天前
|
人工智能 Shell 开发工具
[oeasy]python062_在python中完成输入和输出_input_print
本文介绍了在Python中使用`input()`和`print()`函数完成输入和输出操作的基础知识。通过编写简单的程序,如问候用户和统计苹果数量,演示了如何添加提示信息、处理用户输入并输出结果。同时,回顾了上一次课程内容,包括`input`函数的参数和提示词的使用。文中还展示了如何在vim编辑器中编写和运行Python代码,并对vim和shell的基本操作进行了总结。最后提供了相关学习资源链接,方便读者进一步学习。
101 66
|
2月前
|
Unix Linux 程序员
[oeasy]python053_学编程为什么从hello_world_开始
视频介绍了“Hello World”程序的由来及其在编程中的重要性。从贝尔实验室诞生的Unix系统和C语言说起,讲述了“Hello World”作为经典示例的起源和流传过程。文章还探讨了C语言对其他编程语言的影响,以及它在系统编程中的地位。最后总结了“Hello World”、print、小括号和双引号等编程概念的来源。
122 80
|
2月前
|
人工智能 C语言 Python
[oeasy]python051_什么样的变量名能用_标识符_identifier
本文介绍了Python中变量名的命名规则,强调标识符(identifier)必须以字母或下划线开始,后续可包含字母、下划线及数字。通过`isidentifier()`函数可验证字符串是否为合法标识符。文中还探讨了为何数字不能作为标识符的开头,并提供了相关练习与解答,最后提及这些规则源自C语言的影响。
119 69
|
2月前
|
Python
[oeasy]python050_如何删除变量_del_delete_variable
本文介绍了Python中如何删除变量,通过`del`关键字实现。首先回顾了变量的声明与赋值,说明变量在声明前是不存在的,通过声明赋予其生命和初始值。使用`locals()`函数可查看当前作用域内的所有本地变量。进一步探讨了变量的生命周期,包括自然死亡(程序结束时自动释放)和手动删除(使用`del`关键字)。最后指出,删除后的变量将无法在当前作用域中被访问,并提供了相关示例代码及图像辅助理解。
122 68
|
18天前
|
人工智能 Unix Java
[oeasy]python059变量命名有什么规则_惯用法_蛇形命名法_name_convention_snake
本文探讨了Python中变量命名的几种常见方式,包括汉语拼音变量名、蛇形命名法(snake_case)和驼峰命名法(CamelCase)。回顾上次内容,我们主要讨论了使用下划线替代空格以提高代码可读性。实际编程中,当变量名由多个单词组成时,合理的命名惯例变得尤为重要。
51 9
|
23天前
|
C语言 Python
[oeasy]python058_一句话让python崩了
本文介绍了如何通过重新赋值`__builtins__`使Python环境崩溃,并探讨了下划线的来历及其在编程中的作用。文章回顾了上次内容,展示了覆盖内建模块导致系统崩溃的过程,解释了恢复方法,以及PEP 8规范中关于空格使用的建议。最后,文章总结了下划线在变量定义和提高代码可读性方面的重要性,并简述了其从打字机时代到计算机时代的演变。
30 10
|
2月前
|
Python
[oeasy]python055_python编程_容易出现的问题_函数名的重新赋值_print_int
本文介绍了Python编程中容易出现的问题,特别是函数名、类名和模块名的重新赋值。通过具体示例展示了将内建函数(如`print`、`int`、`max`)或模块名(如`os`)重新赋值为其他类型后,会导致原有功能失效。例如,将`print`赋值为整数后,无法再用其输出内容;将`int`赋值为整数后,无法再进行类型转换。重新赋值后,这些名称失去了原有的功能,可能导致程序错误。总结指出,已有的函数名、类名和模块名不适合覆盖赋新值,否则会失去原有功能。如果需要使用类似的变量名,建议采用其他命名方式以避免冲突。
45 14
|
25天前
|
Python
[oeasy]python057_如何删除print函数_dunder_builtins_系统内建模块
本文介绍了如何删除Python中的`print`函数,并探讨了系统内建模块`__builtins__`的作用。主要内容包括: 1. **回忆上次内容**:上次提到使用下划线避免命名冲突。 2. **双下划线变量**:解释了双下划线(如`__name__`、`__doc__`、`__builtins__`)是系统定义的标识符,具有特殊含义。
29 3
|
28天前
|
存储 Python
[oeasy]python056_python中下划线是什么意思_underscore_理解_声明与赋值_改名字
在Python中,下划线有多种用途。单下划线(_)常用于避免命名冲突,如将`max`改为`max_`以保留内置函数功能。双下划线(__var__)通常用于特殊方法和属性,如`__name__`、`__doc__`等。此外,单下划线(_)在交互式解释器中表示上一次表达式的值,但不建议作为普通变量名使用。总结:下划线用于避免命名冲突及特殊标识。
24 1
|
2月前
|
C语言 Python
[oeasy]python054_python有哪些关键字_keyword_list_列表_reserved_words
本文介绍了Python的关键字列表及其使用规则。通过回顾`hello world`示例,解释了Python中的标识符命名规则,并探讨了关键字如`if`、`for`、`in`等不能作为变量名的原因。最后,通过`import keyword`和`print(keyword.kwlist)`展示了Python的所有关键字,并总结了关键字不能用作标识符的规则。
41 9