2

我已经尝试过像 Lambda、列表理解和其他的序列生成器,但似乎我无法得到我真正想要的东西。我的最终目标是从像string[1:3]这样的字符串打印单词序列

我在找什么:

a = [0,13,26,39]
b = [12,25,38,51]

str = 'If you are done with the file, move to the command area across from the file name in the RL screen and type'

read = str.split()

read[0:12]
['If', 'you', 'are', 'done', 'with', 'the', 'file,', 'move', 'to', 'the', 'command', 'area']
read[13:25]
['from', 'the', 'file', 'name', 'in', 'the', 'RL', 'screen', 'and', 'type']
4

4 回答 4

5

使用zip

>>> a = [0,13,26,39]
>>> b = [12,25,38,51]
>>> strs = 'If you are done with the file, move to the command area across from the file name in the RL screen and type'
>>> spl = strs.split()
>>> for x,y in zip(a,b):
...     print spl[x:y]
...     
['If', 'you', 'are', 'done', 'with', 'the', 'file,', 'move', 'to', 'the', 'command', 'area']
['from', 'the', 'file', 'name', 'in', 'the', 'RL', 'screen', 'and', 'type']
[]
[]

zip返回元组列表,其中每个元组包含来自传递给它的可迭代对象的同一索引上的项目:

>>> zip(a,b)
[(0, 12), (13, 25), (26, 38), (39, 51)]

itertools.izip如果您想要内存高效的解决方案,请使用它,因为它返回一个迭代器。

str.join如果要从该切片列表创建字符串,可以使用:

for x,y in zip(a,b):
    print " ".join(spl[x:y])
...     
If you are done with the file, move to the command area
from the file name in the RL screen and type

更新:创建ab

>>> n = 5
>>> a = range(0, 13*n, 13)
>>> b = [ x + 12 for x in a]
>>> a
[0, 13, 26, 39, 52]
>>> b
[12, 25, 38, 51, 64]
于 2013-06-21T16:59:41.287 回答
3

你的意思是:

>>> [read[i:j] for i, j in zip(a,b)]
[['If', 'you', 'are', 'done', 'with', 'the', 'file,', 'move', 'to', 'the', 
'command',    'area'], ['from', 'the', 'file', 'name', 'in', 'the', 'RL',
'screen', 'and', 'type'], [], []]

或者

>>> ' '.join[read[i:j] for i, j in zip(a,b)][0])
'If you are done with the file, move to the command area'

>>> ' '.join[read[i:j] for i, j in zip(a,b)][1])
'from the file name in the RL screen and type'
于 2013-06-21T17:09:57.560 回答
2
a = [0,13,26,39]
b = [12,25,38,51]
str = 'If you are done with the file, move to the command area across from the file name  in the RL screen and type'

read = str.split()
extra_lists = [read[start:end] for start,end in zip(a,b)]
print extra_lists
于 2013-06-21T17:01:24.093 回答
1

你提到了一个 lambda,所以:

 f = lambda s, i, j: s.split()[i:j]
 >>> f("hello world how are you",0,2)
 ['hello', 'world']

好像你在两个列表中做切片索引,我可以建议一个字典或一个元组列表吗?

str = 'If you are done with the file, move to the command area across from the file name in the RL screen and type'
slices = [(0, 13), (12, 25)]
dslices = {0:13, 12:25}
for pair in slices:
    print f(str, pair[0], pair[1])
for key in dslices:
    print f(str, key, dislikes[key])

当您可以选择更好地格式化数据时,我不喜欢使用 zip。

于 2013-06-21T17:00:33.760 回答