2

我有一个浏览器视图方法,它返回一个包含最多 18 个大脑的 OrderedDict,其起源类似于以下内容:

mydict = OrderedDict()
for b in brains:
    video_obj = b.getObject()
    mydict[b] = {'video_id': video_obj.url,
                 'thumb': video_obj.tag(scale='thumb')} 
return mydict

我可以轻松地遍历它们UL > LI,在 ZPT 中生成一个平面列表:

<ul>
  <li tal:repeat="brain mydict">
    <a tal:attributes="href python:mydict[brain]['video_id']">
      <img tal:replace="mydict[brain]['thumb']" />
    </a>
  </li>
</ul>

但我想要的是一个类似批处理的结构:

<ul>
  <li>
    <a>Item 1</a>
    <a>Item 2</a>
    <a>Item 3</a>
  </li>
  ...
  <li>
    <a>Item 16</a>
    <a>Item 17</a>
    <a>Item 18</a>
  </li>
</ul>

例如:我想将 this{1:2, 2:4, 3:6, 4:8, 5:10, 6:12, 7:14, 8:16, 9:18}转换为 this [{1:2, 2:4, 3:6}, {4:8, 5:10, 6:12}, {7:14, 8:16, 9:18}]

我不想更改浏览器视图,因为模板的其他部分期望 mydict 的键是大脑。

顺便说一句,如果我有一个列表而不是一个 dict 我可以重新组合它的元素:

zip(*[mylist[i::3] for i in range(3)])

但这对于 dicts 是不可能的,而且(奇怪的是 imo)对于 OrderedDicts 也不可能。

4

1 回答 1

4

我认为这是您真正想要的:

from collections import OrderedDict

mydict = OrderedDict()

for i in xrange(18, 0, -1):
    mydict['d{0}'.format(i)] = 'item {0}'.format(i)

regroupped_dict = [OrderedDict(mydict.items()[i: i + 2])
                   for i in xrange(0, len(mydict), 3)]

print regroupped_dict

# Result: [OrderedDict([('d18', 'item 18'), ('d17', 'item 17')]), OrderedDict([('d15', 'item 15'), ('d14', 'item 14')]), OrderedDict([('d12', 'item 12'), ('d11', 'item 11')]), OrderedDict([('d9', 'item 9'), ('d8', 'item 8')]), OrderedDict([('d6', 'item 6'), ('d5', 'item 5')]), OrderedDict([('d3', 'item 3'), ('d2', 'item 2')])]
于 2014-02-24T20:25:28.813 回答