2014-10-01 76 views
0

我有一個列表列表,其中包含包含表示卡片組中的卡片的字符串。我需要垂直打印列表。垂直打印列表清單

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']] 

我需要它來打印,如:

4C AH 3S JS KS 
QD 2C KH 7D 2S 

,並繼續像

+0

我試過嵌套循環,它會打印列表,但e新東西將在新行上,所以在第一個列表完全打印後,它會打印下面的列表。我需要它在它旁邊打印。 – Liam87 2014-10-01 03:19:05

回答

0

使用拉鍊移調列表:

for vlist in zip(*stacks): 
    print ' '.join(vlist) 
+0

謝謝,這工作,但如果一個列表中有一個更多的字符串,它會切斷最後一個字符串。 – Liam87 2014-10-01 03:24:00

+0

使用izip_longest,作爲@mhawke建議 – happydave 2014-10-01 03:28:01

0

您可以使用zip

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']] 
stacks = zip(*stacks) 
print stacks 

OUTPUT

[('4C', 'AH', '3S', 'JS', 'KS'), 
('QD', '2C', 'KH', '7D', '2S'), 
('9D', 'KD', '3H', 'KC', 'QC'), 
('TD', '8C', 'TC', 'QH', '4H'), 
('JH', '5C', 'QS', '6S', '6D'), 
('JD', '5H', '4D', '6H', '9S'), 
('6C', '2D', '7S', '8H', '2H'), 
('AC', '5D', '7H', '8S', '8D'), 
('3C', '7C', '9C', 'JC', '3D'), 
('TS', 'AS', '4S', '5S', '9H')] 
1

前2行是比其餘時間越長,所以使用itertools.izip_longest()代替標準zip()來保存該數據。我使用了填充值'',它用於不等長列表中的缺失值。

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) 

輸出:

4C AH 3S JS KS 
QD 2C KH 7D 2S 
9D KD 3H KC QC 
TD 8C TC QH 4H 
JH 5C QS 6S 6D 
JD 5H 4D 6H 9S 
6C 2D 7S 8H 2H 
AC 5D 7H 8S 8D 
3C 7C 9C JC 3D 
TS AS 4S 5S 9H 
TH AD 

如果你不想在最後一行的雜散空間:

for row in izip_longest(*stacks): 
    print ' '.join(col for col in row if col is not None) 

這裏是一個辦法,只有嵌套循環做到這一點:

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 
+0

我得到一個ImportError,說我無法導入izip_longest是我必須單獨下載的東西嗎?你知道一種獲得相同的輸出,但用循環代替的方法嗎? – Liam87 2014-10-01 03:33:17

+0

izip_longest在itertools中 - 它是一個標準包。你使用的是什麼版本的Python? – mhawke 2014-10-01 03:50:00

+0

Wing IDE版本3.3.4 – Liam87 2014-10-01 03:50:54