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装饰器
装饰器和装饰模式 先给出两者的定义: - 装饰器:装饰器是一个非常著名的设计模式,常常被用于有切面需求的场景.较为经典的有插入日志.性能測试.事务处理等. 装饰器是解决这类问题的绝佳设计.有了装饰器, ...
随机推荐
- PHP截断函数mb_substr()
提示:mb_substr在于php中是默认不被支持的我们需要在在windows目录下找到php.ini打开编辑,搜索mbstring.dll,找到;extension=php_mbstring.dll ...
- GC之二--GC是如何回收时的判断依据、shallow(浅) size、retained(保留) size、Deep(深)size
回到问题“为何会内存溢出?”. 要回答这个问题又要引出另外一个话题,既什么样的对象GC才会回收? 一.对象存活方式判断方法 在上一篇文章<GC之一--GC 的算法分析.垃圾收集器.内存分配策略介 ...
- Tomcat 8(九)解读Tomcat组件的生命周期(Lifecycle)
Tomcat 8(七)解读Bootstrap介绍过.运行startup.bat.将引发Tomcat一连串组件的启动.事实上这一连串启动是通过组件的生命周期(Lifecycle)实现的 今天来看看Lif ...
- swift - UIPickerView 的使用
效果显示数下图: 1.初始化 pickerView.center = self.view.center //将dataSource设置成自己 pickerView.dataSource=self // ...
- 分享一句话的同时说说遍历map的常用方法
最近在网上看到一句话,鄙人觉得这是比较经典的一句话,首先要给大家分享哈: 当一个人找不到出路的时候,最好的办法就是将当前能做好的事情做到极致,做到无人能及. Map<String, String ...
- 远程执行命令:paramiko
paramiko模块用于通过 ssh 登录到远程客户端主机并执行命令,常见用法如下: [root@localhost ~]$ yum install -y python-paramiko 通过用户名密 ...
- nutch 存储到数据库
就像我们知道的一样,nutch是一个架构在lucene之上的网络爬虫+搜索引擎. 是由lucene的作者在lucene基础之上开发,并整合了hadoop,实现在分布式云计算,使用google标准的HF ...
- cookie带来的致命危险
1.危险:当记录了过多的cookie时,可能导致http header过大,进而导致服务器端发生错误,导致用户无法打开页面. 2.cookie限制: 各浏览器对单cookie键的限制基本都在4kb左右 ...
- ubuntu 创建桌面快捷方式
$sudo apt-get install gnome-panel $gnome-desktop-item-edit /home/xxx/桌面 --create-new 命令行:填入程序名称,如/u ...
- 【BZOJ4559】[JLoi2016]成绩比较 动态规划+容斥+组合数学
[BZOJ4559][JLoi2016]成绩比较 Description G系共有n位同学,M门必修课.这N位同学的编号为0到N-1的整数,其中B神的编号为0号.这M门必修课编号为0到M-1的整数.一 ...