鱼C论坛

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

[已解决]python 零基础入门 第30课

[复制链接]
发表于 2018-12-16 23:39:22 | 显示全部楼层 |阅读模式

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

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

x
python 第30课最后一题 实在是太难了,既使是看了老师的答案也无法理解.我有如下问题,望前辈不吝赐教:
#函数代码是老师写的,我截取了其中一部分

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

#我的问题是 上面这个while循环是怎么退出的? 是不是在字符串24个字符(下例)全部序列加完之后,begin ==-1了?

str1 = 'fishc小甲鱼fishc小甲鱼fish小甲鱼' #这里总共是24个字符
pos_in_line(str1,'小甲鱼')


out  [6, 14, 21]

非常感谢!
最佳答案
2018-12-17 00:04:21
本帖最后由 Stubborn 于 2018-12-17 00:09 编辑
  1. def pos_in_line(line, key):   #处理关键字所在行数出现次数函数,文本的一行,关键字 处理关键字在一行出现次数返回一个pos列表
  2.     pos = []                  #新建列表
  3.     begin = line.find(key)        #查找关键数字是否存在,不存在会返回-1的值
  4.     while begin != -1:           #等于-1,则不执行循环
  5.         pos.append(begin + 1)  # 用户的角度是从1开始数,编程才是从0开始
  6.         begin = line.find(key, begin + 1)  # 从下一个位置继续查找

  7.     return pos             #pos是存放了关键字在那行的位置的列表
复制代码



总计一行文本,一个一个查,查到后面总会没有,没有查找到find会返回一个-1的值
这个代码我也看着晕,你看下我的备注把,有什么不懂的问我
  1. import os


  2. def print_pos(key_dict):  #打印及排序字典函数   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):   #处理关键字所在行数出现次数函数,文本的一行,关键字 处理关键字在一行出现次数返回一个pos列表
  8.     pos = []                  #新建列表
  9.     begin = line.find(key)        #查找关键数字是否存在,不存在会返回-1的值
  10.     while begin != -1:           #等于-1,则不执行循环
  11.         pos.append(begin + 1)  # 用户的角度是从1开始数,编程才是从0开始
  12.         begin = line.find(key, begin + 1)  # 从下一个位置继续查找

  13.     return pos             #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) #调用函数处理关键字在一行出现次数返回一个pos列表          # key在每行对应的位置
  22.             key_dict[count] = pos     #count位关键字行数,是key,pos是关键字在一行出现次数在是value。

  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]:    #历遍第三个元组,file
  30.             if os.path.splitext(each_file)[1] == '.txt':  # 根据后缀判断是否文本文件
  31.                 each_file = os.path.join(i[0], each_file)  #把完整路径赋予each_file  i[0]是历遍的路径
  32.                 txt_files.append(each_file)        #把路径添加到列表

  33.     for each_txt_file in txt_files:     #历遍列表   each_txt_file等于完整的txt文本路径
  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)
复制代码

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

使用道具 举报

发表于 2018-12-17 00:04:21 | 显示全部楼层    本楼为最佳答案   
本帖最后由 Stubborn 于 2018-12-17 00:09 编辑
  1. def pos_in_line(line, key):   #处理关键字所在行数出现次数函数,文本的一行,关键字 处理关键字在一行出现次数返回一个pos列表
  2.     pos = []                  #新建列表
  3.     begin = line.find(key)        #查找关键数字是否存在,不存在会返回-1的值
  4.     while begin != -1:           #等于-1,则不执行循环
  5.         pos.append(begin + 1)  # 用户的角度是从1开始数,编程才是从0开始
  6.         begin = line.find(key, begin + 1)  # 从下一个位置继续查找

  7.     return pos             #pos是存放了关键字在那行的位置的列表
复制代码



总计一行文本,一个一个查,查到后面总会没有,没有查找到find会返回一个-1的值
这个代码我也看着晕,你看下我的备注把,有什么不懂的问我
  1. import os


  2. def print_pos(key_dict):  #打印及排序字典函数   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):   #处理关键字所在行数出现次数函数,文本的一行,关键字 处理关键字在一行出现次数返回一个pos列表
  8.     pos = []                  #新建列表
  9.     begin = line.find(key)        #查找关键数字是否存在,不存在会返回-1的值
  10.     while begin != -1:           #等于-1,则不执行循环
  11.         pos.append(begin + 1)  # 用户的角度是从1开始数,编程才是从0开始
  12.         begin = line.find(key, begin + 1)  # 从下一个位置继续查找

  13.     return pos             #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) #调用函数处理关键字在一行出现次数返回一个pos列表          # key在每行对应的位置
  22.             key_dict[count] = pos     #count位关键字行数,是key,pos是关键字在一行出现次数在是value。

  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]:    #历遍第三个元组,file
  30.             if os.path.splitext(each_file)[1] == '.txt':  # 根据后缀判断是否文本文件
  31.                 each_file = os.path.join(i[0], each_file)  #把完整路径赋予each_file  i[0]是历遍的路径
  32.                 txt_files.append(each_file)        #把路径添加到列表

  33.     for each_txt_file in txt_files:     #历遍列表   each_txt_file等于完整的txt文本路径
  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)
复制代码

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

使用道具 举报

 楼主| 发表于 2018-12-17 10:13:10 | 显示全部楼层
非常感谢 Stubborn 的细致解答,主要是我对str.find() 函数不理解,不知道find函数如果没有找到目标对象会返回 -1,才会导致问题的产生。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-5-19 16:37

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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