python with as

举报
不良使 发表于 2022/04/16 20:06:40 2022/04/16
【摘要】 python with as

在这里插入图片描述
🍖🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖
🍖🍖
🍖🍖🍖
🍖🍖🍖🍖 作者 : 不良使
🍖🍖🍖🍖🍖 潜力创作新星 华为云享专家
🍖🍖🍖🍖🍖🍖 博客记录学习的思路,项目和错误,寻找志同道合的朋友
🍖🍖🍖🍖🍖🍖🍖 如果觉得有帮助记得一键三连 ┗|`O′|┛ 嗷~~
🍖🍖🍖🍖🍖🍖🍖🍖

🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖🍖 🍖🍖🍖🍖🍖🍖🍖
在这里插入图片描述
这一题来自于python技能书 ~~~~~~~~~~~~~~~技能数
首先展示一下所需要的结果,下面将详细解说以下代码


代码:

# TODO                鸟欲高飞,必先展翅
# TODO                 向前的人 :Jhon

# todo 实现一个范围耗时统计类。 实现了 __enter__ 和 __exit__ 成员的类,可以通过 with as 语法使用,程序进入和离开范围的时候会自动调用 __enter__ 和 __exit__ 方法。

# -*- coding: UTF-8 -*-
import time


class TimeSpan:
    # TODO(You): 请正确实现计时器的__enter__和__exit成员
    def __enter__(self):
        self.end = None
        self.start = time.time()

    def __exit__(self, exc_type, exc_val, exc_tb):
        self.end = time.time()
        print('耗时:{}毫秒'.format((self.end - self.start)))


if __name__ == '__main__':
    with TimeSpan():
        for i in range(0, 1000):
            print(i)

结果:

在这里插入图片描述
首先来看一下这个题目的要求

实现一个范围耗时统计类。 实现了 enterexit 成员的类,可以通过 with as 语法使用,程序进入和离开范围的时候会自动调用 enterexit 方法。

也就是要你书写一个计数函数,而且此处需要程序进入和离开范围的时候会自动调用 enterexit 方法,简而言之就是记录程序执行的来时时间和结束时间

要计算程序开始和结束的时间当然少不了time模块了(import time)。time.time()就是记录当前时间,想要计算程序的执行时间只需要在程序开始时候记录一下时间(time.time()),程序结束时候记录一下时间(time.time()),计算一下时间差就是此程序的运行时间了【当然,因为程序调用方法的时间非常短,所以忽略不计】

在这里插入图片描述
注意此处 可以 with TimeSpan() as T:,这个知识取别名,方便调用,下面没有用到,所以可以删掉。


在这里插入图片描述

如果只是单纯的计算程序的时间我认为直接在程序前后写上time.time()即可,没必这么复杂,所以这题的主要考察python内置方法的书写。除此之外,选项中还有两种正确的方法,在下面沾上

class TimeSpan:
    def __enter__(self):
        self.end = None
        self.start = time.time()
        return self

    def __exit__(self, exc_type, exc_val, exc_tb):
        self.end = time.time()
        print('耗时:{}毫秒'.format((self.end-self.start)))
class TimeSpan:
    def __enter__(self):
        self.start = time.time()

    def __exit__(self, exc_type, exc_val, exc_tb):
        self.end = time.time()
        print('耗时:{}毫秒'.format((self.end-self.start)))






觉得有帮助的兄弟们请动动小手一键三连吧 -_-

【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。