一、单例
01. 单例设计模式
02. __new__ 方法
重写 __new__ 方法 的代码非常固定!

 class MusicPlayer(object):
 
     def __new__(cls, *args, **kwargs):
         # 如果不返回任何结果,
         return super().__new__(cls)
 
     def __init__(self):
         print("音乐播放器初始化")
 
 
 yunplayer = MusicPlayer()
 print(yunplayer)03. Python 中的单例
单例 —— 让 类 创建的对象,在系统中 只有 唯一的一个实例

 class MusicPlayer(object):
 
     # 定义类属性记录单例对象引用
     instance = None
     def __new__(cls, *args, **kwargs):
         if cls.instance is None:
             return super().__new__(cls)
         
         return cls.instance只执行一次初始化工作
需求
解决办法
 class MusicPlayer(object):
 
     # 记录第一个被创建对象的引用
     instance = None
     # 记录是否执行过初始化动作
     init_flag = False
 
     def __new__(cls, *args, **kwargs):
         # 1.判断类属性是否为空对象
         if cls.instance is None:
             # 2.调用父类方法,为第一个对象分配空间
             return super().__new__(cls)
         # 3.返回类属性保存的对象引用
         return cls.instance
 
     def __init__(self):
         if not MusicPlayer.init_flag:
             print("音乐播放器初始化")
 
             MusicPlayer.init_flag = True
 
 
 # 创建对个对象
 player1 = MusicPlayer()
 print(player1)
 player2 = MusicPlayer()
 print(player2)二、异常
01. 异常的概念

程序开发时,很难将 所有的特殊情况 都处理的面面俱到,通过 异常捕获 可以针对突发事件做集中的处理,从而保证程序的 稳定性和健壮性
02. 捕获异常
2.1 简单的捕获异常语法
try:
    尝试执行的代码
except:
    出现错误的处理简单异常捕获演练 —— 要求用户输入整数
try:
    # 提示用户输入一个数字
    num = int(input("请输入数字:"))
except:
    print("请输入正确的数字")2.2 错误类型捕获
try:
    # 尝试执行的代码
    pass
except 错误类型1:
    # 针对错误类型1,对应的代码处理
    pass
except (错误类型2, 错误类型3):
    # 针对错误类型2 和 3,对应的代码处理
    pass
except Exception as result:
    print("未知错误 %s" % result)异常类型捕获演练 —— 要求用户输入整数
需求
try:
    num = int(input("请输入整数:"))
    result = 8 / num
    print(result)
except ValueError:
    print("请输入正确的整数")
except ZeroDivisionError:
    print("除 0 错误")捕获未知错误
语法如下:
except Exception as result:
    print("未知错误 %s" % result)2.3 异常捕获完整语法
try:
    # 尝试执行的代码
    pass
except 错误类型1:
    # 针对错误类型1,对应的代码处理
    pass
except 错误类型2:
    # 针对错误类型2,对应的代码处理
    pass
except (错误类型3, 错误类型4):
    # 针对错误类型3 和 4,对应的代码处理
    pass
except Exception as result:
    # 打印错误信息
    print(result)
else:
    # 没有异常才会执行的代码
    pass
finally:
    # 无论是否有异常,都会执行的代码
    print("无论是否有异常,都会执行的代码")try:
    num = int(input("请输入整数:"))
    result = 8 / num
    print(result)
except ValueError:
    print("请输入正确的整数")
except ZeroDivisionError:
    print("除 0 错误")
except Exception as result:
    print("未知错误 %s" % result)
else:
    print("正常执行")
finally:
    print("执行完成,但是不保证正确")03. 异常的传递
提示
需求
def demo1():
    return int(input("请输入一个整数:"))
def demo2():
    return demo1()
try:
    print(demo2())
except ValueError:
    print("请输入正确的整数")
except Exception as result:
    print("未知错误 %s" % result)04. 抛出 raise 异常
4.1 应用场景
示例

注意
4.2 抛出异常
需求
def input_password():
    # 1. 提示用户输入密码
    pwd = input("请输入密码:")
    # 2. 判断密码长度,如果长度 >= 8,返回用户输入的密码
    if len(pwd) >= 8:
        return pwd
    # 3. 密码长度不够,需要抛出异常
    # 1> 创建异常对象 - 使用异常的错误信息字符串作为参数
    ex = Exception("密码长度不够")
    # 2> 抛出异常对象
    raise ex
try:
    user_pwd = input_password()
    print(user_pwd)
except Exception as result:
    print("发现错误:%s" % result)三、eval 函数
eval() 函数十分强大 —— 将字符串 当成 有效的表达式 来求值 并 返回计算结果
# 基本的数学计算
In [1]: eval("1 + 1")
Out[1]: 2
# 字符串重复
In [2]: eval("'*' * 10")
Out[2]: '**********'
# 将字符串转换成列表
In [3]: type(eval("[1, 2, 3, 4, 5]"))
Out[3]: list
# 将字符串转换成字典
In [4]: type(eval("{'name': 'xiaoming', 'age': 18}"))
Out[4]: dict案例 - 计算器
需求
input_str = input("请输入一个算术题:")
print(eval(input_str))不要滥用 eval
在开发时千万不要使用 eval 直接转换 input 的结果
__import__('os').system('ls')import os
os.system("终端命令")