搜尋

首頁  >  問答  >  主體

python - 为什么文件搜索时递归不完全?

import os
#os.chdir('C:\Users\Administrator\Desktop\\TEST')


def search(keyword,pathname):
    for f in os.listdir(pathname):
        if os.path.isfile(f):
            if keyword in f:
                print os.path.join(pathname,f)
        if os.path.isdir(f):
            os.chdir(os.path.join(pathname,f))
            pathname=os.getcwd()
            search(keyword,pathname=os.getcwd())
    

if __name__ == "__main__":
    keyword=raw_input('input:')
    pathname=os.getcwd()
    search(keyword,pathname)

本人欲用递归的方式查询并输出文件名中含有关键词的文件,可是此处代码运行后却只能搜索当前目录下的文件,而符合要求的二级、三级目录内的文件却无法检验出?已修改多次,然问题依旧,请相关爱好者及行业从业者交流、指正,谢谢!

大家讲道理大家讲道理2799 天前634

全部回覆(1)我來回復

  • 高洛峰

    高洛峰2017-04-18 09:52:23

    路徑問題,注意檔案的path是指完整的路徑,而不是os.listdir中的字串,修正後的程式如下:

    import os
    
    def search(keyword,pathname):
        for f in os.listdir(pathname):
            real_path = os.path.join(pathname,f)
            if os.path.isfile(real_path):
                if keyword in f:
                   print real_path
            if os.path.isdir(real_path):
                search(keyword,real_path)
    
    if __name__ == "__main__":
        keyword=raw_input('input:')
        pathname=os.getcwd()
        search(keyword,pathname)

    回覆
    0
  • 取消回覆