如何用python获取单个文件 或 文件夹中所有文件的行数


一、获取单个文件的行数

在这里插入图片描述

本例展示获取单个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
[]
[]
===============================================
  • 3
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值