作业1:
通过本周学习的内容,自主设计编写一个Student类,能够统计学生人数.
作业体现形式:
以代码的方式保存成后缀为py的脚本.
作业的注意事项:
1.文件名命名规范.
2.注释清晰.
3.运行结果符合预期效果 .
思路提示:
1.使用Python的class 类的相关模块去实现文件.
2.给Student类增加一个类属性,每创建一个实例,该属性自动增加+1.
作业内容:
- #! /usr/bin/python3
- # ! -*- coding:utf-8 -*-
- '''
- 为了统计学生人数,可以给Student类增加一个类属性,每创建一个实例,该属性自动增加
- '''
- class Student(object):
- # 定义类变量
- count = 0 # 计数,每创建一个对象就加1
- # 初始化变量
- def __init__(self, name):
- self.name = name
- # 每实例化一个学生,就调用一次 count_sum方法,使类变量count+=1
- self.count_sum()
- def count_sum(self):
- Student.count += 1
- if __name__ == '__main__':
- # 实例化Student类
- a = Student('lisi')
- b = Student('wangwu')
- c = Student('zhaoliu')
- d = Student('maqi')
- e = Student('liuba')
- print('共创建学生:{}个'.format(Student.count))
测试运行结果:
作业2:
通过本周学习的内容,自主编写设计一个装饰器,它可以作用于任何函数上,打印函数的执行时间.
作业体现形式:
以代码的方式保存成后缀为py的脚本.
作业的注意事项:
1.文件名命名规范.
2.注释清晰.
3.运行结果符合预期效果 .
思路提示:
1.装饰器的简单理解:实际上就是为了给一个程序添加额外的功能,但是该程序已经上线或者已被使用,那么就不能大批量的修改源码,这样不现实,因此就产生了装饰器的概念。
2.函数的传递参数:*args, **kwargs 代表函数可以接受所有类型所有格式的参数.
3.引入datetime,time模块来计算函数的运行时间和时间格式的转化.
作业内容:
- #! /usr/bin/python3
- # ! -*- coding:utf-8 -*-
- '''
- 设计一个装饰器,它可以作用于任何函数上,打印函数的执行时间
- '''
- import datetime
- import time
- def metric(func):
- '''自定义计时装饰器'''
- # *args, **kwargs 代表该方法可以接受所有类型所有格式的参数。
- def wrapper(*args, **kwargs):
- # 计算函数开始的时间
- start = datetime.datetime.now()
- # 调用传入的函数方法
- func(*args, **kwargs)
- # 计算函数结束的时间
- end=datetime.datetime.now()
- # 计算函数运行所用的时间
- times=end-start
- # 将算出来的函数进行格式的转化和输出.
- print("%s 执行耗时 %f 秒" % (func.__name__,times.total_seconds())) #time是datetime.timedelta类型,后六位是微秒
- # 这里的return可以理解为 调用装饰器以后,返回wrapper方法,相当于将测试用的mysum方法当做参数传到wapper中进行调用.
- return wrapper
- '''
- 装饰器的调用方式:在调用的函数前边使用 @装饰器 的方式,使装饰器生效.
- '''
- @metric
- # 定义测试函数,测试自定义的计时器是否生效.
- def mysum():
- lista = [x for x in range(1000000)]
- time.sleep(3)
- if __name__ == '__main__':
- # 调用函数,测试结果.
- mysum()
测试运行结果: