Python-装饰器-案例-获取文件列表
import os def get_all_path(fun):
'''装饰器。功能:获取全路径文件名。如:D:/tmp/12.txt
:param fun:
:return:file_path_list 全路径文件名列表
''' def inner(r):
# print("获取全路径文件名")
file_name_list = fun(r)
file_path_list = []
for file in file_name_list:
path_file = refer_path + os.sep + file
file_path_list.append(path_file)
return file_path_list return inner def get_pdf(fun):
'''装饰器。功能:获取后缀为pdf、PDF的文件名列表
:param fun:
:return: file_pdf_list后缀为pdf、PDF的文件名列表
''' def inner(r):
# print("获取后缀为.pdf的文件名列表")
file_name_list = fun(r)
file_pdf_list = []
for file in file_name_list:
ext = os.path.splitext(file)[1]
if ext.lower() == '.pdf': # 判断后缀是否为.pdf、.PDF
file_pdf_list.append(file)
return file_pdf_list return inner def get_suffix_out(suf="txt"):
'''装饰器。功能:获取后缀为指定后缀(suf)的文件名列表
:param suf:指定后缀,如:txt、jpg
:return:suf_list符合指定后缀的文件列表
''' def get_suffix(fun):
def inner(*args, **kwargs):
# print("inner 后缀限制是:", suf)
# # print("获取后缀为.pdf的文件名列表")
file_name_list = fun(*args, **kwargs)
suf_list = []
for file in file_name_list:
src_suf = os.path.splitext(file)[1] # 获取文件的后缀,如:.pdf、.txt
if src_suf.lower() == '.' + str(suf).lower(): # 判断后缀是否为.suf、.SUF
suf_list.append(file)
return suf_list return inner return get_suffix def get_papers_only(fun):
'''装饰器。功能:只获取列表中的文件名。不含文件夹。如:1.txt、123.pdf
:param fun:
:return: file_name_only_list 只有文件名,不含文件夹的列表
''' def inner(r):
# print("只获取文件名,不含文件夹")
file_name_list = fun(r)
# 只获取文件名,不含文件夹列表。如:1.txt、123.pdf
file_name_only_list = []
for file in file_name_list:
if os.path.isabs(file): # 1、如果为绝对路径,r表示绝对路径全路径列表
if not os.path.exists(file): # 检查全路径的有效性
print("路径不存在")
exit()
if os.path.isfile(file): # 判断是否为文件(非文件夹)
file_name_only_list.append(file)
else: # 2、如果为相对路径,r表示相对路径统一路径字符串
path_file = r + os.sep + file
if not os.path.exists(path_file): # 检查全路径的有效性
print("路径不存在")
exit()
if os.path.isfile(path_file): # 判断是否为文件(非文件夹)
file_name_only_list.append(file)
return file_name_only_list return inner # 巧用装饰器做过滤条件
@get_all_path # 获取全路径文件列表。如:[D:\tmp\123.pdf]
@get_pdf # 获取pdf后缀列表。如:[123.pdf]
@get_papers_only # 只获取文件列表,不含文件夹。如:[a、b、1.txt、123.pdf]
def get_list(refer_path):
'''获取指定路径下的所有文件列表(含文件夹)。如:a、b、1.txt、123.pdf
:param refer_path: 指定存放文件的路径
:return:路径下的所有文件名
'''
try:
file_name_list = os.listdir(refer_path)
return file_name_list
except Exception as e:
print(e)
exit() @get_papers_only # 只获取文件列表,不含文件夹。如:[a、b、1.txt、123.pdf]
@get_suffix_out("txt") # 只获取txt后缀列表。如:[D:\tmp\123.txt]
# @get_pdf # 只获取pdf后缀列表。如:[D:\tmp\123.pdf]
def all_path(all_path_list):
return all_path_list if __name__ == '__main__':
# 指定路径
refer_path = r'D:\tmp'
# 文件名称列表
file_name_list = get_list(refer_path)
print(file_name_list) path_list = ['D:\\tmp\\123.PDF',
'D:\\tmp\\combinedminutes.txt',
'D:\\tmp\\mark.pdf',
'D:\\tmp\\meetingminutes.ps',
'D:\\tmp\\meetingminutes2.123',
'D:\\tmp\\rotatedpage.pdf',
'D:\\tmp\\watermarkedCover.pdf'] print(path_list)
pdf_list = all_path(path_list)
print(pdf_list)
==================优美的分割线==================
装饰器学习案例:
例子1:简单装饰器
def check(fun):
def inner():
print("权限检查--1")
fun() return inner @check
def foo1():
print("查看用户信息") if __name__ == '__main__':
foo1()
例子2:被装饰函数待有参数的装饰器
def check(fun):
def inner(*args, **kwargs):
print("权限检查--1")
fun(*args, **kwargs) return inner @check
def foo1():
print("查看用户信息") if __name__ == '__main__':
foo1()
例子3:装饰器带参数的装饰器
def check_out(who):
def check(fun):
def inner(*args, **kwargs):
print("权限检查--1,部门时:%s" % who)
fun(*args, **kwargs) return inner return check @check_out("天猫")
def foo1(a, b):
print("查看用户信息%s" % (a + b)) @check_out("闲鱼")
def foo2(a, b, c):
print("查看用户信息%s" % (a + b + c)) if __name__ == '__main__':
foo1(1, 2)
foo2(1, 2,3)
例子4:类语法版本的装饰器
class MyClass(object):
def __init__(self, fun):
print('__init__函数:fun=', fun)
self.fun = fun def __call__(self, *args, **kwargs):
print("验证权限")
return self.fun(*args, **kwargs) @MyClass
def foo1(a, b):
print("%s + %s = %s" % (a, b, (a + b))) if __name__ == '__main__':
foo1(1,2)
例子5:文档恢复为被装饰器的文档的装饰器
import functools def check(fun):
"""检查权限的装饰器"""
@functools.wraps(fun)
def inner(*args, **kwargs):
"""这里是闭包函数"""
print("权限检查--1")
fun(*args, **kwargs) return inner @check
def foo1():
'''这里是原始函数foo1的说明文档'''
print("查看用户信息") if __name__ == '__main__':
print(foo1.__doc__)
参考:https://www.cnblogs.com/andy9468/p/11137417.html
Python-装饰器-案例-获取文件列表的更多相关文章
- python装饰器内获取函数有用信息方法
装饰器内获取函数有用信息方法 .__doc__用于得到函数注释信息 .__name_用于得到函数名 在函数引用装饰器的时候,函数名会变为装饰器内部执行该函数的名字,所有在直接执行函数名加.__doc_ ...
- 简学Python第四章__装饰器、迭代器、列表生成式
Python第四章__装饰器.迭代器 欢迎加入Linux_Python学习群 群号:478616847 目录: 列表生成式 生成器 迭代器 单层装饰器(无参) 多层装饰器(有参) 冒泡算法 代码开发 ...
- python——获取文件列表
"""-------------------------------------------------------- <<获取文件列表>> () ...
- [python 基础]python装饰器(一)添加functools获取原函数信息以及functools.partial分析
python装饰器学习的时候有两点需要注意一下 1,被装饰器装饰的函数取其func.__name__和func.func_doc的时候得到的不是被修饰函数的相关信息而是装饰器wrapper函数的doc ...
- python 装饰器、递归原理、模块导入方式
1.装饰器原理 def f1(arg): print '验证' arg() def func(): print ' #.将被调用函数封装到另外一个函数 func = f1(func) #.对原函数重新 ...
- Python 装饰器入门(上)
翻译前想说的话: 这是一篇介绍python装饰器的文章,对比之前看到的类似介绍装饰器的文章,个人认为无人可出其右,文章由浅到深,由函数介绍到装饰器的高级应用,每个介绍必有例子说明.文章太长,看完原文后 ...
- python 装饰器 一篇就能讲清楚
装饰器一直是我们学习python难以理解并且纠结的问题,想要弄明白装饰器,必须理解一下函数式编程概念,并且对python中函数调用语法中的特性有所了解,使用装饰器非常简单,但是写装饰器却很复杂.为了讲 ...
- Python高级特性: 12步轻松搞定Python装饰器
12步轻松搞定Python装饰器 通过 Python 装饰器实现DRY(不重复代码)原则: http://python.jobbole.com/84151/ 基本上一开始很难搞定python的装 ...
- 装饰模式和python装饰器
装饰器和装饰模式 先给出两者的定义: - 装饰器:装饰器是一个非常著名的设计模式,常常被用于有切面需求的场景.较为经典的有插入日志.性能測试.事务处理等. 装饰器是解决这类问题的绝佳设计.有了装饰器, ...
随机推荐
- DOTween中的Time.Scale
因为在做游戏暂停的时候通常会使用Time.Scale = 0 ,可是暂停的时候UI如果需要继续有动画怎么办呢?在DoTween中只需要设置 tweener.SetUpdate(true ...
- SQL中查询语句的使用
常用SQL查询语句 - myLittleGarden - 博客园 http://www.cnblogs.com/sunada2005/p/3411873.html 一.简单查询语句 1. 查看表结构 ...
- Excel时间格式修改为文本格式
- 上千万或上亿数据(有反复),统计当中出现次数最多的N个数据. C++实现
上千万或上亿的数据,如今的机器的内存应该能存下.所以考虑採用hash_map/搜索二叉树/红黑树等来进行统计次数. 然后就是取出前N个出现次数最多的数据了,能够用第2题提到的堆机制完毕. #inclu ...
- Codeforces Round #313 D. Equivalent Strings(DFS)
D. Equivalent Strings time limit per test 2 seconds memory limit per test 256 megabytes input standa ...
- 静态变量数组实现LRU算法
LRU算法的解释详情请见 https://baike.baidu.com/item/LRU/1269842 这里百度百科给出的比较详细,然后后面有一个例子 说 LRU(least recently u ...
- Dubbo源码导入Eclipse遇到的问题
1.怎么将Dubbo源码导入到Eclipse 方法一: 打开Eclipse,File-->Import-->maven-->Exsting Maven Projects,选择dubb ...
- Python cookielib 模块
什么是 cookie : 指某些网站为了辨别用户身份,进行 session 跟踪而储存在用户本地终端上的数据,通常以 txt 文件形式存储.比如你登录了淘宝,浏览器就会保存 cookie 信息,这样我 ...
- osgEarth使用没有DX的Triton库Triton-MT-DLL-NODX.lib
将Triton-MT-DLL修改为Triton-MT-DLL-NODX
- [原创]用Oreans UnVirtualizer还原VM代码
标题:[原创]用Oreans UnVirtualizer还原VM代码实验 作者:sungy 时间:2014-09-18 对VM一直很头痛,在逆向实践一般尽量想办法避开它,当黑盒来处理.有时候不面对她又 ...