鱼C论坛

 找回密码
 立即注册
查看: 2173|回复: 2

[已解决]文件相关问题

[复制链接]
发表于 2022-4-14 22:09:00 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 代码小白liu 于 2022-4-14 22:11 编辑

这个代码是怎么实现“当前文件夹内包含文件夹,则进入文件夹继续搜索”的功能的,i[2]部分是将walk返回的文件进行判断了呀



  1. import os


  2. def print_pos(key_dict):
  3.     keys = key_dict.keys()
  4.     keys = sorted(keys)  # 由于字典是无序的,我们这里对行数进行排序
  5.     for each_key in keys:
  6.         print('关键字出现在第 %s 行,第 %s 个位置。' % (each_key, str(key_dict[each_key])))


  7. def pos_in_line(line, key):
  8.     pos = []
  9.     begin = line.find(key)
  10.     while begin != -1:
  11.         pos.append(begin + 1)  # 用户的角度是从1开始数
  12.         begin = line.find(key, begin + 1)  # 从下一个位置继续查找

  13.     return pos


  14. def search_in_file(file_name, key):
  15.     f = open(file_name)
  16.     count = 0  # 记录行数
  17.     key_dict = dict()  # 字典,用户存放key所在具体行数对应具体位置

  18.     for each_line in f:
  19.         count += 1
  20.         if key in each_line:
  21.             pos = pos_in_line(each_line, key)  # key在每行对应的位置
  22.             key_dict[count] = pos

  23.     f.close()
  24.     return key_dict


  25. def search_files(key, detail):
  26.     all_files = os.walk(os.getcwd())
  27.     txt_files = []

  28.     for i in all_files:
  29.         for each_file in i[2]:
  30.             if os.path.splitext(each_file)[1] == '.txt':  # 根据后缀判断是否文本文件
  31.                 each_file = os.path.join(i[0], each_file)
  32.                 txt_files.append(each_file)

  33.     for each_txt_file in txt_files:
  34.         key_dict = search_in_file(each_txt_file, key)
  35.         if key_dict:
  36.             print('================================================================')
  37.             print('在文件【%s】中找到关键字【%s】' % (each_txt_file, key))
  38.             if detail in ['YES', 'Yes', 'yes']:
  39.                 print_pos(key_dict)


  40. key = input('请将该脚本放于待查找的文件夹内,请输入关键字:')
  41. detail = input('请问是否需要打印关键字【%s】在文件中的具体位置(YES/NO):' % key)
  42. search_files(key, detail)
复制代码
最佳答案
2022-4-14 22:20:37
给你一个初始目录d:\test。
问,该目录下总共有多少目录和文件。
你能看到的只能是d:\test当前有多少文件和目录,其后的子目录有些什么你不知道。os.listdir('d:\test')能获取当前目录下的目录和文件。
这时你便可以一个一个目录进去用同样的方法来获取目录下的目录和文件。这就是递归方法。
递归方法:
  1. import os

  2. def gci(filepath):
  3.   # 遍历filepath下所有文件,包括子目录
  4.   files = os.listdir(filepath)
  5.   for fi in files:
  6.     fi_d = os.path.join(filepath,fi)            
  7.     if os.path.isdir(fi_d):
  8.       gci(fi_d)                  
  9.     else:
  10.       print(fi_d)

  11. #递归遍历/root目录下所有文件
  12. gci('d:\test')
复制代码

而你的代码中用了现成的方法os.walk()来获取d:\test下的所有目录和文件(包括子目录)
  1. import os
  2. for fpathe,dirs,fs in os.walk('d:\test'):
  3.   for f in fs:
  4.     print(os.path.join(fpathe,f))
复制代码


小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-4-14 22:20:37 | 显示全部楼层    本楼为最佳答案   
给你一个初始目录d:\test。
问,该目录下总共有多少目录和文件。
你能看到的只能是d:\test当前有多少文件和目录,其后的子目录有些什么你不知道。os.listdir('d:\test')能获取当前目录下的目录和文件。
这时你便可以一个一个目录进去用同样的方法来获取目录下的目录和文件。这就是递归方法。
递归方法:
  1. import os

  2. def gci(filepath):
  3.   # 遍历filepath下所有文件,包括子目录
  4.   files = os.listdir(filepath)
  5.   for fi in files:
  6.     fi_d = os.path.join(filepath,fi)            
  7.     if os.path.isdir(fi_d):
  8.       gci(fi_d)                  
  9.     else:
  10.       print(fi_d)

  11. #递归遍历/root目录下所有文件
  12. gci('d:\test')
复制代码

而你的代码中用了现成的方法os.walk()来获取d:\test下的所有目录和文件(包括子目录)
  1. import os
  2. for fpathe,dirs,fs in os.walk('d:\test'):
  3.   for f in fs:
  4.     print(os.path.join(fpathe,f))
复制代码


小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-14 22:42:46 | 显示全部楼层
本帖最后由 jackz007 于 2022-4-14 22:44 编辑
  1. root , dirs , files = os . walk(os . getcwd())
复制代码

      该调用返回一个有 3 个元素(root , dirs , files) 元组的生成器,会从当前目录(os . getcwd()) 开始,递归扫描每一个子目录,每扫描完一个子目录,就反馈一次 root,dirs 和 files,其中,root 是子目录的绝对路径,dirs 是该目录内所有子目录的列表,files 是该子目录内所有普通文件的列表。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-29 08:29

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表