擅长:python、mysql、java
<p>前2行比其余行长,因此使用<code>itertools.izip_longest()</code>而不是标准的<code>zip()</code>来保存该数据。我使用了一个填充值<code>''</code>,它用于不等长列表中的缺失值。在</p>
<pre><code>from itertools import izip_longest
stacks = [['4C', 'QD', '9D', 'TD', 'JH', 'JD', '6C', 'AC', '3C', 'TS', 'TH'], ['AH', '2C', 'KD', '8C', '5C', '5H', '2D', '5D', '7C', 'AS', 'AD'], ['3S', 'KH', '3H', 'TC', 'QS', '4D', '7S', '7H', '9C', '4S'], ['JS', '7D', 'KC', 'QH', '6S', '6H', '8H', '8S', 'JC', '5S'], ['KS', '2S', 'QC', '4H', '6D', '9S', '2H', '8D', '3D', '9H']]
for row in izip_longest(*stacks, fillvalue=''):
print ' '.join(row)
</code></pre>
<p>输出:</p>
^{pr2}$
<p>如果您不想在最后一行留下空白:</p>
<pre><code>for row in izip_longest(*stacks):
print ' '.join(col for col in row if col is not None)
</code></pre>
<p>以下是仅使用嵌套循环执行此操作的方法:</p>
<pre><code>longest = max(len(row) for row in stacks)
for i in range(longest):
for row in stacks:
if i < len(row):
print row[i],
print
</code></pre>