作业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()
测试运行结果: