在 python 中读取文本文件并将其拆分为单个单词

2025-02-21 08:48:00
admin
原创
22
摘要:问题描述:我有这个由数字和单词组成的文本文件,例如像这样 -09807754 18 n 03 aristocrat 0 blue_blood 0 patrician我想将其拆分,以便每个单词或数字都作为新行出现。空格分隔符是理想的,因为我想让带有破折号的单词保持连接。这是我目前所拥有的:f = open('w...

问题描述:

我有这个由数字和单词组成的文本文件,例如像这样 -09807754 18 n 03 aristocrat 0 blue_blood 0 patrician我想将其拆分,以便每个单词或数字都作为新行出现。

空格分隔符是理想的,因为我想让带有破折号的单词保持连接。

这是我目前所拥有的:

f = open('words.txt', 'r')
for word in f:
    print(word)

不太确定从这里开始该怎么做,我希望这是输出:

09807754
18
n
3
aristocrat
...

解决方案 1:

鉴于此文件:

$ cat words.txt
line1 word1 word2
line2 word3 word4
line3 word5 word6

如果您一次只想获取一个单词(忽略文件中空格和换行符的含义):

with open('words.txt','r') as f:
    for line in f:
        for word in line.split():
           print(word)    

印刷:

line1
word1
word2
line2
...
word6 

类似地,如果您想将文件扁平化为文件中的单个扁平单词列表,您可以执行以下操作:

with open('words.txt') as f:
    flat_list=[word for line in f for word in line.split()]

>>> flat_list
['line1', 'word1', 'word2', 'line2', 'word3', 'word4', 'line3', 'word5', 'word6']

它能创建与第一个例子相同的输出`print '
'.join(flat_list)`......

或者,如果您想要文件每一行中单词的嵌套列表(例如,从文件中创建行和列的矩阵):

with open('words.txt') as f:
    matrix=[line.split() for line in f]

>>> matrix
[['line1', 'word1', 'word2'], ['line2', 'word3', 'word4'], ['line3', 'word5', 'word6']]

如果您想要一个正则表达式解决方案,它将允许您过滤示例文件中的单词wordN与类型:lineN

import re
with open("words.txt") as f:
    for line in f:
        for word in re.findall(r'wordd+', line):
            # wordN by wordN with no lineN

或者,如果您希望使用正则表达式逐行生成器:

 with open("words.txt") as f:
     (word for line in f for word in re.findall(r'w+', line))

解决方案 2:

f = open('words.txt')
for word in f.read().split():
    print(word)

解决方案 3:

作为补充,如果你正在读取一个非常大的文件,并且你不想一次将所有内容读入内存,你可以考虑使用缓冲区,然后通过yield返回每个单词:

def read_words(inputfile):
    with open(inputfile, 'r') as f:
        while True:
            buf = f.read(10240)
            if not buf:
                break

            # make sure we end on a space (word boundary)
            while not str.isspace(buf[-1]):
                ch = f.read(1)
                if not ch:
                    break
                buf += ch

            words = buf.split()
            for word in words:
                yield word
        yield '' #handle the scene that the file is empty

if __name__ == "__main__":
    for word in read_words('./very_large_file.txt'):
        process(word)

解决方案 4:

你可以使用 nltk 来标记单词,然后将所有单词存储在列表中,这就是我所做的。如果你不了解 nltk;它代表自然语言工具包,用于处理自然语言。如果你想开始,这里有一些资源 [ http://www.nltk.org/book/]

import nltk 
from nltk.tokenize import word_tokenize 
file = open("abc.txt",newline='')
result = file.read()
words = word_tokenize(result)
for i in words:
       print(i)

输出将是这样的:

09807754
18
n
03
aristocrat
0
blue_blood
0
patrician

解决方案 5:

with open(filename) as file:
    words = file.read().split()

这是文件中所有单词的列表。

import re
with open(filename) as file:
    words = re.findall(r"([a-zA-Z-]+)", file.read())

解决方案 6:

以下是我完全实用的方法,可以避免读取和拆分行。它利用了itertools模块:

注意对于 Python 3,请替换itertools.imapmap

import itertools

def readwords(mfile):
    byte_stream = itertools.groupby(
        itertools.takewhile(lambda c: bool(c),
            itertools.imap(mfile.read,
                itertools.repeat(1))), str.isspace)

    return ("".join(group) for pred, group in byte_stream if not pred)

使用示例:

>>> import sys
>>> for w in readwords(sys.stdin):
...     print (w)
... 
I really love this new method of reading words in python
I
really
love
this
new
method
of
reading
words
in
python
           
It's soo very Functional!
It's
soo
very
Functional!
>>>

我想,就你的情况而言,这将是使用该函数的方式:

with open('words.txt', 'r') as f:
    for word in readwords(f):
        print(word)
相关推荐
  为什么项目管理通常仍然耗时且低效?您是否还在反复更新电子表格、淹没在便利贴中并参加每周更新会议?这确实是耗费时间和精力。借助软件工具的帮助,您可以一目了然地全面了解您的项目。如今,国内外有足够多优秀的项目管理软件可以帮助您掌控每个项目。什么是项目管理软件?项目管理软件是广泛行业用于项目规划、资源分配和调度的软件。它使项...
项目管理软件   1325  
  IPD(Integrated Product Development)流程作为一种先进的产品开发管理模式,在众多企业中得到了广泛应用。它涵盖了从产品概念产生到产品退市的整个生命周期,通过整合跨部门团队、优化流程等方式,显著提升产品开发的效率和质量,进而为项目的成功奠定坚实基础。深入探究IPD流程的五个阶段与项目成功之间...
IPD流程分为几个阶段   4  
  华为作为全球知名的科技企业,其成功背后的管理体系备受关注。IPD(集成产品开发)流程作为华为核心的产品开发管理模式,其中的创新管理与实践更是蕴含着丰富的经验和深刻的智慧,对众多企业具有重要的借鉴意义。IPD流程的核心架构IPD流程旨在打破部门墙,实现跨部门的高效协作,将产品开发视为一个整体的流程。它涵盖了从市场需求分析...
华为IPD是什么   3  
  IPD(Integrated Product Development)研发管理体系作为一种先进的产品开发模式,在众多企业的发展历程中发挥了至关重要的作用。它不仅仅是一套流程,更是一种理念,一种能够全方位提升企业竞争力,推动企业持续发展的有效工具。深入探究IPD研发管理体系如何助力企业持续发展,对于众多渴望在市场中立足并...
IPD管理流程   3  
  IPD(Integrated Product Development)流程管理旨在通过整合产品开发流程、团队和资源,实现产品的快速、高质量交付。在这一过程中,有效降低成本是企业提升竞争力的关键。通过优化IPD流程管理中的各个环节,可以在不牺牲产品质量和性能的前提下,实现成本的显著降低,为企业创造更大的价值。优化产品规划...
IPD流程分为几个阶段   4  
热门文章
项目管理软件有哪些?
云禅道AD
禅道项目管理软件

云端的项目管理软件

尊享禅道项目软件收费版功能

无需维护,随时随地协同办公

内置subversion和git源码管理

每天备份,随时转为私有部署

免费试用