How to separate tokens in line using Unix?

[in]:

some sentences are like this.
some sentences foo bar that

[out:]

some
sentences
are
like
this.

some
sentences
foo
bar
that

I could have done this in python as below, but is there any unix way to achieve the same output?

>>> import codecs
>>> outfile = codecs.open('outfile.txt','w','utf8')
>>> intext = "some sentences are like this.\n some sentences foo bar that"
>>> infile = codecs.open('infile.txt','w','utf8')
>>> print>>infile, intext
>>> for i in codecs.open('infile.txt','r','utf8'):
...     for j in i.split():
...             print>>outfile, j
...     print>>outfile
... 
>>> exit()

alvas@ubi:~$ cat outfile.txt 
some
sentences
are
like
this.

some
sentences
foo
bar
that
有帮助吗?

解决方案

Using sed:

$ cat infile.txt
some sentences are like this.
some sentences foo bar that
$ sed 's/\s\+\|$/\n/g' infile.txt > outfile.txt
$ cat outfile.txt
some
sentences
are
like
this.

some
sentences
foo
bar
that

其他提示

Using xargs

xargs -n1 < file
sed -e 's/ \|$/\n/g' < text

should do?

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top