python os.path.isfile函数

  最近刚开始学习Python,做了个小练习:扫描当前目录及其子目录中的文件,找出文件名中含有指定关键字的文件并打印文件名。思路很简单,如果是文件则判断是否满足条件;如果是目录则进入目录搜索文件,递归。文章来源地址https://www.yii666.com/article/764062.html网址:yii666.com<

  思路有了那就准备开撸

 #!/usr/bin/env python
# -*- coding: utf-8 -*- import os
import sys def search(token):
for file in os.listdir('.'):
if os.path.isfile(file): #如果是文件
if token in file:
print file
elif os.path.isdir(file): #如果是目录
os.chdir(file)
search(token) if __name__ == '__main__':
search(sys.argv[1])

撸完测试,发现结果跟想象的不一样,遇到子目录后就退出了,通过调试发现递归函数返回后再次判断file是否为文件时,结果都是否,后来修改了os.path.isfile函数的参数:在for循环前利用os.getcwd函数获取当前路径并保存,再结合os.path.join函数拼接file形成绝对路径,这样修改后,程序运行结果符合预期。

  通过比对分析,问题应该出在os.path.isfile函数处,官方文档上对该函数的说明也比较简略:网址:yii666.com文章来源地址:https://www.yii666.com/article/764062.html

os.path.isfile(path)
Return True if path is an existing regular file. This follows symbolic links, so both islink() and isfile() can be true for the same path.

既然对于绝对路径的判断该函数返回结果没问题,而代码中传入的参数是相对(当前)路径的,那说明os.path.isfile函数在处理相对路径的文件时,默认是当前工作目录,恰好代码中再递归调用search函数时修改了当前工作目录,这就导致递归返回后os.path.isfile函数判断结果与预期不符,修改后代码如下:

 #!/usr/bin/env python
# -*- coding: utf-8 -*- import os
import sys def search(token):
pwd = os.getcwd()
for file in os.listdir('.'):
if os.path.isfile(file): #如果是文件
if token in file:
print file
elif os.path.isdir(file): #如果是目录
os.chdir(file)
search(token)
os.chdir(pwd)

if __name__ == '__main__':
search(sys.argv[1])

结论

  在调用os.path.isfile函数判断是否为普通文件时,若传入的路径是相对路径,则默认是在当前工作目录下搜索该文件。文章地址https://www.yii666.com/article/764062.html

版权声明:本文内容来源于网络,版权归原作者所有,此博客不拥有其著作权,亦不承担相应法律责任。文本页已经标记具体来源原文地址,请点击原文查看来源网址,站内文章以及资源内容站长不承诺其正确性,如侵犯了您的权益,请联系站长如有侵权请联系站长,将立刻删除

python os.path.isfile函数-相关文章

  1. group_concat() 函数 拼接字符串长度有限制

  2. mysql函数拼接查询concat函数

  3. SQL STUFF函数 拼接字符串

  4. MySQL的Date()函数拼接

  5. '{}/{}_frames_{:02d}.npy'.format(dataset, train_or_test, i+1)函数

  6. python os.path.isfile函数

  7. MySQL中limit使用动态参数的解决方法(拼接SQL字符串语句来执行SQL)

    官方好像说过limit已经在5.6版本上支持了动态参数,但是测试时依然还是不行。那么要解决limit动态参数唯一能做的就是使用字符串SQL拼接的形式,然后再进行执行。一般有以下方式解决:1、存储过程拼接2、函数拼接3、视图里拼接4、当前查询的session中使用其实上面都是同一

  8. Mysql经常使用函数

    -----------------------------字符串函数-------------------------------------------拼接字符串。不论什么字符串与null拼接为nullselect concat(\\\'aaa\\\',\\\'bbb\\\',\\\'ccc\\\'),concat(null,\\\'aaa\\\');----从第12个字符后開始的三个字符替换成meselect insert (\\\'beijing2008you\\\',12,3,\\\'me\\\');----下标从1開始select insert (\\\'beijing\\\',1,2,\\\'oo\\\');---大写和

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信图片_20190322181744_03.jpg

微信扫一扫打赏

请作者喝杯咖啡吧~

支付宝扫一扫领取红包,优惠每天领

二维码1

zhifubaohongbao.png

二维码2

zhifubaohongbao2.png