[Python进阶]002.装饰器(1)
装饰器(1)
介绍
- Python的装饰器叫
Decorator,就是对一个模块做装饰。 - 作用: 为已存在的对象添加额外功能。
 - 与Java中的注解相似,就是在方法前加@XXX来对这个方法做装饰。
 - 与Java中的注解相当复杂不同,Python的装饰器相当简单。
 - 函数式编程
 - 面向切片编程
 
HelloWorld
需求
def fun(i):
print i
这是一个简单的方法,现在我们要在执行这个方法前后在执行一些其他代码,比如计算运行时间。
简单的方式就是:
import time def fun(i):
t = time.time()
print i
t = time.time() - t # 计算运行时间
print '运行时间:',str(t) # 打印时间
这种方式不方便,也不能复用。
使用函数式编程
import time # 计算运行时间
def exec_time(fn, i): # fn:方法; i:方法的参数
t = time.time()
fn(i) # 调用fn
t = time.time() - t # 计算运行时间
print '运行时间:',str(t) # 打印时间 def fun(i):
print i # 调用
exec_time(fun, i)
使用这种方式,在实际调用时,需要包裹一层exec_time方法,虽然可以复用,使用起来但也并不灵活。
加入装饰器
下面我们就来加入修饰器
from functools import wraps # 引入装饰器需要的包
import time # 定义一个装饰器
def exec_time(fn): # 参数fn:要修饰的方法,就是我们的fun
@wraps(fn)
def _(i): # 修饰方法,参数i是fun传过来的参数
t = time.time()
fn(i) # 执行方法
t = time.time() - t
print '运行时间:',str(t)
return _ # 返回修饰后方法
这样就完成了一个计算运行时间的装饰器。
@exec_time
def fun(i):
print i @exec_time
def fun2(i):
print 'fun2', i
使用起来十分方便。
解析
- 加入了
@exec_time后的fun方法,在调用时会自动调用相当于exec_time(fun)的方法。 fun方法被exec_time装饰了,方法在开始和结束时会进行计时,并打印花费时间,这就是一个横切面,这种编程方式就是面向切面的编程。在方法执行的过程中横向插入逻辑,在很多地方都能大量减少重复代码。

本站文章为宝宝巴士 SD.Team原创,转载务必在明显处注明:(作者官方网站:宝宝巴士) 
转载自【宝宝巴士SuperDo团队】 原文链接: http://www.cnblogs.com/superdo/p/4829345.html
 *:first-child {
  margin-top: 0 !important; }
body > *:last-child {
  margin-bottom: 0 !important; }
a {
  color: #4183C4;
  text-decoration: none; }
a.absent {
  color: #cc0000; }
a.anchor {
  display: block;
  padding-left: 30px;
  margin-left: -30px;
  cursor: pointer;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0; }
h1, h2, h3, h4, h5, h6 {
  margin: 20px 0 10px;
  padding: 0;
  font-weight: bold;
  -webkit-font-smoothing: antialiased;
  cursor: text;
  position: relative; }
h1:hover a.anchor, h2:hover a.anchor, h3:hover a.anchor, h4:hover a.anchor, h5:hover a.anchor, h6:hover a.anchor {
  background: url() no-repeat 10px center;
  text-decoration: none; }
h1 tt, h1 code {
  font-size: inherit; }
h2 tt, h2 code {
  font-size: inherit; }
h3 tt, h3 code {
  font-size: inherit; }
h4 tt, h4 code {
  font-size: inherit; }
h5 tt, h5 code {
  font-size: inherit; }
h6 tt, h6 code {
  font-size: inherit; }
h1 {
  font-size: 28px;
  color: black; }
h2 {
  font-size: 24px;
  border-bottom: 1px solid #cccccc;
  color:#00ccff;
  margin: 25px auto 12px auto;
  padding-bottom: 2px;
}
h3 {
  font-size: 18px;
  color:#993300;}
h4 {
  font-size: 16px; }
h5 {
  font-size: 14px; }
h6 {
  color: #777777;
  font-size: 14px; }
p, blockquote, ul, ol, dl, li, table, pre {
  margin: 0 0; }
/*hr {
  background: transparent url() repeat-x 0 0;
  border: 0 none;
  color: #cccccc;
  height: 4px;
  padding: 0;
}*/
hr {
    margin: 0 0 19px;
    border: 0;
    border-bottom: 1px solid #ccc;
}
body > h2:first-child {
  margin-top: 0;
  padding-top: 0; }
body > h1:first-child {
  margin-top: 0;
  padding-top: 0; }
  body > h1:first-child + h2 {
    margin-top: 0;
    padding-top: 0; }
body > h3:first-child, body > h4:first-child, body > h5:first-child, body > h6:first-child {
  margin-top: 0;
  padding-top: 0; }
a:first-child h1, a:first-child h2, a:first-child h3, a:first-child h4, a:first-child h5, a:first-child h6 {
  margin-top: 0;
  padding-top: 0; }
h1 p, h2 p, h3 p, h4 p, h5 p, h6 p {
  margin-top: 0; }
li p.first {
  display: inline-block; }
li {
  margin: 0; }
ul, ol {
  padding-left: 30px; }
ul :first-child, ol :first-child {
  margin-top: 0; }
dl {
  padding: 0; }
  dl dt {
    font-size: 14px;
    font-weight: bold;
    font-style: italic;
    padding: 0;
    margin: 15px 0 5px; }
    dl dt:first-child {
      padding: 0; }
    dl dt > :first-child {
      margin-top: 0; }
    dl dt > :last-child {
      margin-bottom: 0; }
  dl dd {
    margin: 0 0 15px;
    padding: 0 15px; }
    dl dd > :first-child {
      margin-top: 0; }
    dl dd > :last-child {
      margin-bottom: 0; }
blockquote {
  border-left: 4px solid #dddddd;
  padding: 0 15px;
  color: #777777; }
  blockquote > :first-child {
    margin-top: 0; }
  blockquote > :last-child {
    margin-bottom: 0; }
/*table {
  padding: 0;border-collapse: collapse; }
  table tr {
    border-top: 1px solid #cccccc;
    background-color: white;
    margin: 0;
    padding: 0; }
    table tr:nth-child(2n) {
      background-color: #f8f8f8; }
    table tr th {
      font-weight: bold;
      border: 1px solid #cccccc;
      margin: 0;
      padding: 6px 13px; }
    table tr td {
      border: 1px solid #cccccc;
      margin: 0;
      padding: 6px 13px; }
    table tr th :first-child, table tr td :first-child {
      margin-top: 0; }
    table tr th :last-child, table tr td :last-child {
      margin-bottom: 0; }*/
img {
  max-width: 100%; }
span.frame {
  display: block;
  overflow: hidden; }
  span.frame > span {
    border: 1px solid #dddddd;
    display: block;
    float: left;
    overflow: hidden;
    margin: 13px 0 0;
    padding: 7px;
    width: auto; }
  span.frame span img {
    display: block;
    float: left; }
  span.frame span span {
    clear: both;
    color: #333333;
    display: block;
    padding: 5px 0 0; }
span.align-center {
  display: block;
  overflow: hidden;
  clear: both; }
  span.align-center > span {
    display: block;
    overflow: hidden;
    margin: 13px auto 0;
    text-align: center; }
  span.align-center span img {
    margin: 0 auto;
    text-align: center; }
span.align-right {
  display: block;
  overflow: hidden;
  clear: both; }
  span.align-right > span {
    display: block;
    overflow: hidden;
    margin: 13px 0 0;
    text-align: right; }
  span.align-right span img {
    margin: 0;
    text-align: right; }
span.float-left {
  display: block;
  margin-right: 13px;
  overflow: hidden;
  float: left; }
  span.float-left span {
    margin: 13px 0 0; }
span.float-right {
  display: block;
  margin-left: 13px;
  overflow: hidden;
  float: right; }
  span.float-right > span {
    display: block;
    overflow: hidden;
    margin: 13px auto 0;
    text-align: right; }
code, tt {
  margin: 0 2px;
  padding: 0 0px;
  white-space: nowrap;
  /*background-color: #fff;*/
  color: rgba(51, 102, 255, 255);
  /*border: 1px solid #eaeaea;*/
  /*background-color: #f8f8f8;*/
  /*border-radius: 3px; */}
pre code {
  margin: 0;
  padding: 0;
  white-space: pre;
  border: none;
  color: rgba(0, 0, 0, 255);
  background: transparent; }
.highlight pre {
  background-color: #f8f8f8;
  border: 1px solid #cccccc;
  font-size: 13px;
  line-height: 19px;
  overflow: auto;
  padding: 6px 10px;
  border-radius: 3px; }
pre {
  background-color: #f8f8f8;
  border: 1px solid #cccccc;
  font-size: 14px;
  line-height: 19px;
  overflow: auto;
  padding: 6px 10px;
  border-radius: 3px; }
  pre code, pre tt {
    background-color: transparent;
    border: none; }
sup {
    font-size: 0.83em;
    vertical-align: super;
    line-height: 0;
}
* {
	-webkit-print-color-adjust: exact;
}
@media screen and (min-width: 914px) {
    body {
        /*width: 854px;*/
        /*margin:0 auto;*/
    }
}
@media print {
	table, pre {
		page-break-inside: avoid;
	}
	pre {
		word-wrap: break-word;
	}
}
#cnblogs_post_body li ul li {
    list-style-type: circle !important;
}
#cnblogs_post_body a {
    text-decoration: none;
    color: #4183C4;
}
#mainContent .postBody h2 {
  margin: 25px auto 12px auto;
  padding-bottom: 2px;
}
-->
[Python进阶]002.装饰器(1)的更多相关文章
- python进阶04 装饰器、描述器、常用内置装饰器
		
python进阶04 装饰器.描述器.常用内置装饰器 一.装饰器 作用:能够给现有的函数增加功能 如何给一个现有的函数增加执行计数的功能 首先用类来添加新功能 def fun(): #首先我们定义一个 ...
 - Python进阶(六)----装饰器
		
Python进阶(六)----装饰器 一丶开放封闭原则 开放原则:  增加一些额外的新功能 封闭原则:  不改变源码.以及调用方式 二丶初识装饰器 装饰器:  也可称装饰器函数,诠释开放封闭原则 ...
 - Python进阶之装饰器
		
函数也是对象 要理解Python装饰器,首先要明白在Python中,函数也是一种对象,因此可以把定义函数时的函数名看作是函数对象的一个引用.既然是引用,因此可以将函数赋值给一个变量,也可以把函数作为一 ...
 - Python进阶: Decorator 装饰器你太美
		
函数 -> 装饰器 函数的4个核心概念 1.函数可以赋与变量 def func(message): print('Got a message: {}'.format(message)) send ...
 - python进阶(三)~~~装饰器和闭包
		
一.闭包 满足条件: 1. 函数内嵌套一个函数: 2.外层函数的返回值是内层函数的函数名: 3.内层嵌套函数对外部作用域有一个非全局变量的引用: def func(): print("=== ...
 - python进阶:装饰器
		
1.闭包 简单理解:闭包就是多层函数的嵌套,外层函数的返回值是内层函数的引用. def out_func(n): num = 100 def in_fucn(*args,**kwargs): # no ...
 - Python进阶(装饰器)
		
from datetime import datetime def log(func):#func表示装饰器作用于的函数 def wrapper(*args,**kw):#wrapper返回装饰器作用 ...
 - 简单说明Python中的装饰器的用法
		
简单说明Python中的装饰器的用法 这篇文章主要简单说明了Python中的装饰器的用法,装饰器在Python的进阶学习中非常重要,示例代码基于Python2.x,需要的朋友可以参考下 装饰器对与 ...
 - 【Python】【装饰器】
		
Python中的装饰器是你进入Python大门的一道坎,不管你跨不跨过去它都在那里. 为什么需要装饰器 我们假设你的程序实现了say_hello()和say_goodbye()两个函数. def sa ...
 
随机推荐
- Effective C++学习记录
			
Effective C++算是看完了,但是并没有完全理解,也做不到记住所有,在此记录下55个条款及条款末的"请记住". 让自己习惯C++ 条款01:视C++为一个语言联邦 ① C ...
 - 如何在Windows下安装MySQL5和MySQL8的多实例
			
MySQL5和MySQL8多实例安装方法: 1.首先下载MySQL5和MySQL8 官方下载链接:https://dev.mysql.com/downloads/mysql/ 下载旧版本: 下载好后 ...
 - Spring源码阅读 之 搭建源码阅读环境(IDEA)
			
检出源码: GitHub:https://github.com/spring-projects/spring-framework.git 可以按如下步骤:(须确保Git已正确安装) Git正确安装后, ...
 - 如何理解三大运营商发布的《5G消息白皮书》?
			
如何理解三大运营商发布的<5G消息白皮书>? 2020年4月8日中国移动.中国电信.中国联通携手华为.小米.vivo.OPPO.中兴等11家终端厂商联合发布了<5G消息白皮书> ...
 - [hdu5400 Arithmetic Sequence]预处理,容斥
			
题意:http://acm.hdu.edu.cn/showproblem.php?pid=5400 思路:预处理出每个点向左和向右的最远边界,从左向右枚举中间点,把区间答案加到总答案里面.由与可能与前 ...
 - 记一次Oracle分区表全局索引重建的过程
			
1.查询数据库各个表空间利用率: SELECT Upper(F.TABLESPACE_NAME) "表空间名", D.TOT_GROOTTE_MB "表空间大小(M)&q ...
 - 理解css属性的继承和覆盖
			
首先,我们梳理一下哪些属性会被继承 文本 color 颜色,a元素除外 direction 方向 font 字体 font-family 字体系列 font-style 字体风格 font-size ...
 - 自建nodejs服务器(一:有个服务器)
			
之前在阿里云备案过,也买过域名和虚拟主机(6元一年),可惜虚拟主机虽然说可选linux或windows系统,但linux系统只支持几个php程序,一番折腾,云栖社区的大伙们都说要弄node得买个ECS ...
 - 中国空气质量在线监测分析平台之JS加密、JS混淆处理
			
中国空气质量在线监测分析平台数据爬取分析 页面分析:确定url.请求方式.请求参数.响应数据 1.访问网站首页:https://www.aqistudy.cn/html/city_detail.htm ...
 - DPDK Hash Library原理(学习笔记)
			
0 前言 本文主要翻译至DPDK的官方编程指南,在谷歌翻译的基础上根据自己的理解做了一些修改.网上搜索的很多中文翻译大多是翻译后直接黏贴上来,有时候连语句都读不通.希望本文能够对你有所帮助. 1 介绍 ...