如何获取一个文本文件的行数?
接下来,我们对
【方法1】
思路:借助readlines
def readline_count(file_name):
return len(open(file_name,encoding="utf-8").readlines())
cnt=readline_count(file_path)
print(cnt)
【方法2】
思路:依次读取文件每行内容进行计数:
def simple_count(file_name):
lines = 0
for _ in open(file_name):
lines += 1
return lines
【方法3】
思路:使用sum函数计数
def sum_count(file_name):
return sum(1 for _ in open(file_name))
【方法4】
思路:enumerate枚举计数:
def enumerate_count(file_name):
with open(file_name) as f:
for count, _ in enumerate(f, 1):
pass
return count
【方法5】
思路:每次读取固定大小,然后统计行数
def buff_count(file_name):
with open(file_name, 'rb') as f:
count = 0
buf_size = 1024 * 1024
buf = f.read(buf_size)
while buf:
count += buf.count(b'\n')
buf = f.read(buf_size)
return count
【方法6】
思路:调用使用wc命令计算行
def wc_count(file_name):
import subprocess
out = subprocess.getoutput("wc -l %s" % file_name)
return int(out.split()[0])
【方法7】
思路:在buff_count基础上引入partial
def partial_count(file_name):
from functools import partial
buffer = 1024 * 1024
with open(file_name) as f:
return sum(x.count('\n') for x in iter(partial(f.read, buffer), ''))
【方法8】
思路:在buff_count基础上引入itertools模块
def iter_count(file_name):
from itertools import (takewhile, repeat)
buffer = 1024 * 1024
with open(file_name) as f:
buf_gen = takewhile(lambda x: x, (f.read(buffer) for _ in repeat(None)))
return sum(buf.count('\n') for buf in buf_gen)
性能对比
| 方法 | 100M | 500M | 1G | 10G |
|---|---|---|---|---|
| readline_count | 0.25 | 1.82 | 3.27 | 45.04 |
| simple_count | 0.13 | 0.85 | 1.58 | 13.53 |
| sum_count | 0.15 | 0.77 | 1.59 | 14.07 |
| enumerate_count | 0.15 | 0.80 | 1.60 | 13.37 |
| buff_count | 0.13 | 0.62 | 1.18 | 10.21 |
| wc_count | 0.09 | 0.53 | 0.99 | 9.47 |
| partial_count | 0.12 | 0.55 | 1.11 | 8.92 |
| iter_count | 0.08 | 0.42 | 0.83 | 8.33 |
本文详细介绍了8种获取文本文件行数的方法,包括readlines、逐行计数、sum函数、enumerate、缓冲读取、wc命令、partial和itertools迭代。通过性能测试对比,展示了在不同文件大小下各方法的优劣。
795





