63

我有这个由数字和单词组成的文本文件,例如像这样 -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
...
4

6 回答 6

153

鉴于此文件:

$ 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 '\n'.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']]

如果您想要一个正则表达式解决方案,这将允许您在示例文件中过滤wordNlineN键入单词:

import re
with open("words.txt") as f:
    for line in f:
        for word in re.findall(r'\bword\d+', 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))
于 2013-06-04T15:56:17.487 回答
22
f = open('words.txt')
for word in f.read().split():
    print(word)
于 2013-06-04T16:05:39.417 回答
15

作为补充,如果您正在读取一个非常大的文件,并且您不想一次将所有内容读入内存,您可以考虑使用缓冲区,然后通过 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)
于 2017-03-11T07:03:56.867 回答
5

您可以做的是使用 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
于 2018-03-24T11:37:18.980 回答
4
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())
于 2019-01-20T08:38:13.790 回答
1

这是我完全实用的方法,它避免了读取和拆分行。它利用了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)
于 2016-11-29T05:22:49.180 回答