修饰器的作用是接收一个方法,为方法添加一些功能后返回。
需要注意的几点:
- 修饰器接收方法后,需要将添加一些功能后的方法返回。
- 修饰器可以借用接收方法的参数。
- 修饰器可以按顺序多次被使用。
下面,就用之前的文件检索方法,演示修饰器的使用。
#coding:utf-8
"""
Note:
获取文件的改变
Author:redsun
Data:2019/7/10
"""
import re
import time
import os
def WarpperHead(fun):
'''
给函数添加最外层修饰
:param fun: 被修饰的函数名
:return:
'''
def HelpInfoHead( File_Path, KeyWord):
'''
外层修饰
:param File_Path: 参数
:param KeyWord: 参数
:return:
'''
file_name = os.path.basename(File_Path)
print('---'* 20)
print('Search File ({file_name}) about "({KeyWord})" Info ...'.format(file_name=file_name, KeyWord = KeyWord).title())
print(GetTime())
# 修饰的函数传递
fun(File_Path, KeyWord)
print ('End'.center(60))
print('---'* 20)
# 返回返回调用
return HelpInfoHead
def WarpperContent(fun):
def HelpInfoContent(*args):
'''
参数的传递
:param args:
:return:
'''
print('***' * 20)
fun(*args)
print('***' * 20)
return HelpInfoContent
def GetTime():
'''
返回当前时间
:return:
'''
return time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(time.time()))
@WarpperHead
@WarpperContent
def GetFileKeyInfo(File_Path, KeyWord):
'''
检索文件中与关键字相关的行,并输出
:param File_Path: 文件路径
:param KeyWord: 关键字
:return: 输出关键字所在的行
'''
with open(File_Path) as f:
lines = f.readlines()
if len(lines) == 0:
print("日志文件为空".center(50, '='))
else:
count = 0
text = ''
for line in lines:
rs = re.search(KeyWord, line)
if rs:
count += 1
text += line
print('[命中{count}次]'.format(count=count))
print(text)
GetFileKeyInfo('E:\\TestCode\\PyCharmProjects\\xiaoxiang\\PrintFIileChange\\word', 'uiui')