[oeasy]python0145_版本控制_git_备份还原
off999 2025-07-10 19:56 15 浏览 0 评论
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
- 制作备份
- 进行回滚
- 尝试了 嵌套的控制结构
- 层层 控制
- 不过 非到不得以
- 尽量不要 太多层次的嵌套
- 虽然这样 从顶到底
- 含义 明确
- 扁平 难道就不能
- 含义明确么?
- 还可以 做点什么?
- 让程序更加明确呢?
- 我们下次再说!
- 蓝桥->https://www.lanqiao.cn/courses/3584
- github->https://github.com/overmind1980/oeasy-python-tutorial
- gitee->https://gitee.com/overmind1980/oeasypython
相关推荐
- Linux 网络协议栈_linux网络协议栈
-
前言;更多学习资料(包含视频、技术学习路线图谱、文档等)后台私信《资料》免费领取技术点包含了C/C++,Linux,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,Z...
- 揭秘 BPF map 前生今世_bpfdm
-
1.前言众所周知,map可用于内核BPF程序和用户应用程序之间实现双向的数据交换,为BPF技术中的重要基础数据结构。在BPF程序中可以通过声明structbpf_map_def...
- 教你简单 提取fmpeg 视频,音频,字幕 方法
-
ffmpeg提取视频,音频,字幕方法(HowtoExtractVideo,Audio,SubtitlefromOriginalVideo?)1.提取视频(ExtractVi...
- Linux内核原理到代码详解《内核视频教程》
-
Linux内核原理-进程入门进程进程不仅仅是一段可执行程序的代码,通常进程还包括其他资源,比如打开的文件,挂起的信号,内核内部的数据结构,处理器状态,内存地址空间,或多个执行线程,存放全局变量的数据段...
- Linux C Socket UDP编程详解及实例分享
-
1、UDP网络编程主要流程UDP协议的程序设计框架,客户端和服务器之间的差别在于服务器必须使用bind()函数来绑定侦听的本地UDP端口,而客户端则可以不进行绑定,直接发送到服务器地址的某个端口地址。...
- libevent源码分析之bufferevent使用详解
-
libevent的bufferevent在event的基础上自己维护了一个buffer,这样的话,就不需要再自己管理一个buffer了。先看看structbufferevent这个结构体struct...
- 一次解决Linux内核内存泄漏实战全过程
-
什么是内存泄漏:程序向系统申请内存,使用完不需要之后,不释放内存还给系统回收,造成申请的内存被浪费.发现系统中内存使用量随着时间的流逝,消耗的越来越多,例如下图所示:接下来的排查思路是:1.监控系统中...
- 彻底搞清楚内存泄漏的原因,如何避免内存泄漏,如何定位内存泄漏
-
作为C/C++开发人员,内存泄漏是最容易遇到的问题之一,这是由C/C++语言的特性引起的。C/C++语言与其他语言不同,需要开发者去申请和释放内存,即需要开发者去管理内存,如果内存使用不当,就容易造成...
- linux网络编程常见API详解_linux网络编程视频教程
-
Linux网络编程API函数初步剖析今天我们来分析一下前几篇博文中提到的网络编程中几个核心的API,探究一下当我们调用每个API时,内核中具体做了哪些准备和初始化工作。1、socket(family...
- Linux下C++访问web—使用libcurl库调用http接口发送解析json数据
-
一、背景这两天由于一些原因研究了研究如何在客户端C++代码中调用web服务端接口,需要访问url,并传入json数据,拿到返回值,并解析。 现在的情形是远程服务端的接口参数和返回类型都是json的字符...
- 平衡感知调节:“系统如人” 视角下的架构设计与业务稳定之道
-
在今天这个到处都是数字化的时代,系统可不是一堆冷冰冰的代码。它就像一个活生生的“数字人”,没了它,业务根本转不起来。总说“技术要为业务服务”,但实际操作起来问题不少:系统怎么才能快速响应业务需求?...
- 谈谈分布式文件系统下的本地缓存_什么是分布式文件存储
-
在分布式文件系统中,为了提高系统的性能,常常会引入不同类型的缓存存储系统(算法优化所带来的的效果可能远远不如缓存带来的优化效果)。在软件中缓存存储系统一般可分为了两类:一、分布式缓存,例如:Memca...
- 进程间通信之信号量semaphore--linux内核剖析
-
什么是信号量信号量的使用主要是用来保护共享资源,使得资源在一个时刻只有一个进程(线程)所拥有。信号量的值为正的时候,说明它空闲。所测试的线程可以锁定而使用它。若为0,说明它被占用,测试的线程要进入睡眠...
- Qt编写推流程序/支持webrtc265/从此不用再转码/打开新世界的大门
-
一、前言在推流领域,尤其是监控行业,现在主流设备基本上都是265格式的视频流,想要在网页上直接显示监控流,之前的方案是,要么转成hls,要么魔改支持265格式的flv,要么265转成264,如果要追求...
- 30 分钟搞定 SpringBoot 视频推拉流!实战避坑指南
-
30分钟搞定SpringBoot视频推拉流!实战避坑指南在音视频开发领域,SpringBoot凭借其快速开发特性,成为很多开发者实现视频推拉流功能的首选框架。但实际开发中,从环境搭建到流处理优...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)