我正在编写将CSV转换为XML的代码。假设我有一个单独的列表,如:带有多个可变长度元素的Python列表理解?
input = ['name', 'val', 0, \
'name', 'val', 1, 'tag', 'val', \
'name', 'val', 2, 'tag', 'val', 'tag', 'val', \
'name', 'val', 0]
这个列表以“名”的每一个切片表示一个名称,一个值,和可选的标记值对一个可变数目的元素。
我想变成这样:
output = [['name', 'val', []],
['name', 'val', ['tag', 'val']],
['name', 'val', ['tag', 'val', 'tag', 'val']],
['name', 'val', []]]
无需标签 - 值对分离到的元组,这是在一个单独的方法来处理。我有一个解决方案,但它不是非常符合Python:
output=[]
cursor=0
while cursor < len(input):
name=input[cursor]
val=input[cursor+1]
ntags=int(input[cursor+2])
optslice=input[cursor+3:cursor+3+2*ntags]
cursor = cursor+3+2*ntags
print name, val, ntags, optslice, cursor
output.append([name, val, optslice])
print output
> name val 0 [] 3
> name val 1 ['tag', 'val'] 8
> name val 2 ['tag', 'val', 'tag', 'val'] 15
> name val 0 [] 18
> [['name', 'val', []], ['name', 'val', ['tag', 'val']], ['name', 'val', ['tag', 'val', 'tag', 'val']], ['name', 'val', []]]
我想我大概可以做到这一点作为一个列表理解,但每个元素的可变长度是扔我一个循环。输入是从CSV解析的,我可以更改格式以更好地适应不同的解决方案。想法?