huangdongdong 发表于 2021-2-25 12:31:49

第29讲

def file_view(file_name, line_num):
    if line_num.strip() == ':':
      begin = '1'
      end = '-1'
      
    (begin, end) = line_num.split(':')

    if begin == '':
      begin = '1'
    if end == '':
      end = '-1'

    if begin == '1' and end == '-1':
      prompt = '的全文'
    elif begin == '1':
      prompt = '从开始到%s' % end
    elif end == '-1':
      prompt = '从%s到结束' % begin
    else:
      prompt = '从第%s行到第%s行' % (begin, end)

    print('\n文件%s%s的内容如下:\n' % (file_name, prompt))

    begin = int(begin) - 1
    end = int(end)
    lines = end - begin

    f = open(file_name)
   
    for i in range(begin):# 用于消耗掉begin之前的内容
      f.readline()

    if lines < 0:
      print(f.read())
    else:
      for j in range(lines):
            print(f.readline(), end='')
   
    f.close()

file_name = input(r'请输入要打开的文件(C:\\test.txt):')
line_num = input('请输入需要显示的行数【格式如 13:21 或 :21 或 21: 或 : 】:')
file_view(file_name, line_num)



    for i in range(begin):# 用于消耗掉begin之前的内容
      f.readline()

    if lines < 0:
      print(f.read())
    else:
      for j in range(lines):
            print(f.readline(), end='')
求这几行代码的解释

Ⅲ只小猪 发表于 2021-2-25 12:31:50

本帖最后由 Ⅲ只小猪 于 2021-2-25 17:17 编辑

for i in range(begin):# 用于消耗掉begin之前的内容:将文件指针定位到begin行的末尾,及begin下一行的开头
      f.readline() #从文件读取整行,包括 "\n" 字符,就是读取文件中的其中一行,此时文件的指针已经定位到了第begin行的末尾(下一行的开头)

if lines < 0: # 如果lines小于0,这就代表begin大于end,因为前面有lines = end - begin,但是因为lines小于0,不能倒着打印文件!就比如无法打印文件第5行到第3行
    print(f.read()) # 读取整个文件并打印,

else: # 否则:如果lines大于0,说明begin小于end

    for j in range(lines): # 打印文件指针前 lines 行的内容,注意:文件指针在第31行代码已经改变了,所以会从文件指针处开始打印前lines行的内容
      print(f.readline(), end='')
            """
            打印文件 lines行的内容,因为是for循环,且readline读取整行
            所以每循环一次,就打印一次,读取文件的时候指针就向下移动一行。
            于是就会不断打印余下的行,直到循环结束
            """

Peteryo01223 发表于 2021-2-25 16:52:31

本帖最后由 Peteryo01223 于 2021-2-25 17:08 编辑

if lines < 0: #如果 lines 的值小于零,即 end 的行数在 begin 的行数之前,这其实说明输入者输入的范围有点儿问题,比如:从第13行读到第2行,颠倒的读法儿。
         print(f.read()) # 读取f文件,至结束为止,全打印出来
   else: # 如果是其他情况,即: lines 的值不小于 0,也就是一般人认为的正常读取范围, end 的行数在 begin 的行数之后或者是同一行
         for j in range(lines): # 针对行“数”的每一个数字。这句和下面一句,是利用python,在试图依次调用“规定范围中”的每一行txt
             print(f.readline(), end='') # 每读一行内容,依次打印出来。

Ⅲ只小猪 发表于 2021-2-25 19:17:11

楼主解决了吗。。。

huangdongdong 发表于 2021-2-25 21:53:35

Ⅲ只小猪 发表于 2021-2-25 12:31


for i in range(begin):
      f.readline()
这两行代码的目的是什么

Ⅲ只小猪 发表于 2021-2-25 22:05:13

huangdongdong 发表于 2021-2-25 21:53
for i in range(begin):
      f.readline()
这两行代码的目的是什么

如果直接range循环的话,就算是range(3,9),那也只会从第一行开始打印前6行,假如我们要输入3:9从第三行开始打印,就需要先移动文件的指针,而这些代码正是这个作用,即把文件指标向下移动begin行
页: [1]
查看完整版本: 第29讲