使用 Python 对文本文件进行排序
- 2025-03-11 08:50:00
- admin 原创
- 105
问题描述:
我有一个包含超过 1000 万行的文本文件。类似这样的行:
37024469;196672001;255.0000000000
37024469;196665001;396.0000000000
37024469;196664001;396.0000000000
37024469;196399002;85.0000000000
37024469;160507001;264.0000000000
37024469;160506001;264.0000000000
如您所见,分隔符是“;”。我想使用 python 根据第二个元素对此文本文件进行排序。我无法使用 split 函数。因为它会导致 MemoryError。我该如何处理它?
解决方案 1:
不要在内存中对 1000 万行进行排序。而是将其分成几批:
运行 100 次 100k 行排序(使用文件作为迭代器,结合
islice()
或类似地选择一批)。写出到其他地方的单独文件中。合并排序后的文件。这是一个合并生成器,您可以传递 100 个打开的文件,它会按排序顺序生成行。逐行写入新文件:
import operator
def mergeiter(*iterables, **kwargs):
"""Given a set of sorted iterables, yield the next value in merged order
Takes an optional `key` callable to compare values by.
"""
iterables = [iter(it) for it in iterables]
iterables = {i: [next(it), i, it] for i, it in enumerate(iterables)}
if 'key' not in kwargs:
key = operator.itemgetter(0)
else:
key = lambda item, key=kwargs['key']: key(item[0])
while True:
value, i, it = min(iterables.values(), key=key)
yield value
try:
iterables[i][0] = next(it)
except StopIteration:
del iterables[i]
if not iterables:
raise
解决方案 2:
基于使用 Python 在 2MB RAM 中对一百万个 32 位整数进行排序:
import sys
from functools import partial
from heapq import merge
from tempfile import TemporaryFile
# define sorting criteria
def second_column(line, default=float("inf")):
try:
return int(line.split(";", 2)[1]) # use int() for numeric sort
except (IndexError, ValueError):
return default # a key for non-integer or non-existent 2nd column
# sort lines in small batches, write intermediate results to temporary files
sorted_files = []
nbytes = 1 << 20 # load around nbytes bytes at a time
for lines in iter(partial(sys.stdin.readlines, nbytes), []):
lines.sort(key=second_column) # sort current batch
f = TemporaryFile("w+")
f.writelines(lines)
f.seek(0) # rewind
sorted_files.append(f)
# merge & write the result
sys.stdout.writelines(merge(*sorted_files, key=second_column))
# clean up
for f in sorted_files:
f.close() # temporary file is deleted when it closes
heapq.merge()
`key自 Python 3.5 以来具有参数。您可以尝试
mergeiter()`使用 Martijn Pieters 的答案,或者在较旧的 Python 版本上执行Schwartzian 变换:
iters = [((second_column(line), line) for line in file)
for file in sorted_files] # note: this makes the sort unstable
sorted_lines = (line for _, line in merge(*iters))
sys.stdout.writelines(sorted_lines)
用法:
$ python sort-k2-n.py < input.txt > output.txt
解决方案 3:
os.system()
你可以通过调用 bash 函数来实现sort
sort -k2 yourFile.txt
相关推荐
热门文章
项目管理软件有哪些?
热门标签
曾咪二维码
扫码咨询,免费领取项目管理大礼包!
云禅道AD