Python教程:如何获取单个文件或文件夹中所有文件的行数

目录

  • 一、获取单个文件的行数
  • 二、获取文件夹中所有文件的行数
  • 三、关于os.walk()函数

  • 一、获取单个文件的行数

    本例展示获取单个txt文件中的行数:

    #统计单个文件的行数
    cnt = 0;
    #open后面的参数是你想要获得文件行数的那个文件(目标文件)
    with open("labels/718_5m_cloudy_other_0805.txt",'rb') as f:
        for line in f:
            cnt = cnt+1
    print(cnt)
    

    二、获取文件夹中所有文件的行数

    本例展示获取labels下的所有txt文件内容的总行数:

    import os
    
    total_line_num = 0  # 总行数
    #分别表示 root 、root下的文件夹名 、root下的文件名 (括号里传递的参数是base_path)
    for base_path, folder_list, file_list in os.walk('D:\count_lines'):
        for file_name in file_list:
            file_path = os.path.join(base_path, file_name)
            count = 0
            with open(file_path, 'rb') as f:
                for line in f:
                    count += 1
            total_line_num += count
    print('总行数:', total_line_num-13-6) #减去count.py和test.py文件内容的行数
    

    三、关于os.walk()函数

    1. 函数解释
      os.walk()是一种遍历目录数的函数,机理类似深度优先搜索和层次搜索策略,其返回的是
      root dirs files
    2. 返回值解释
      root:代表当前遍历的目录路径,string类型
      dirs:代表root路径下的所有子目录名称,list类型,列表中的每个元素是string类型,代表子目录名称。
      files:代表root路径下的所有子文件名称,返回list类型,列表中的每个元素是string类型,代表子文件名称。
    import os
    
    home_path = "/test" #最好传相对地址
    for (root, dirs, files) in os.walk(home_path):
        print(root)
        print(dirs)
        print(files)
        print("===============================================")
    

    目录结构:

    输出结果:

    /test
    ['A', 'B', 'C']
    ['a.txt', 'b.txt', 'os.walk().py']
    ===============================================
    /test\A
    []
    ['A_1.txt', 'A_2.txt', 'A_3.txt']
    ===============================================
    /test\B
    []
    ['B_1.txt', 'B_2.txt', 'B_3.txt']
    ===============================================
    /test\C
    []
    []
    ===============================================
    
    物联沃分享整理
    物联沃-IOTWORD物联网 » Python教程:如何获取单个文件或文件夹中所有文件的行数

    发表评论