2017-09-27 77 views
0

我想合併2d列表中的單元格,新行合併到下一個空行上。努力用邏輯來設計這個。我解析了一個html表格並將其轉換爲二維列表,並希望合併由空行分隔的行。 例如。python合併2維列表中的單元格上的行

data = [[a, b, c] 
[d, e, f] 
['','',''] 
[q, r, s] 
[t, u, v] 
[m, n, o] 
['','',''] 
[g, h, i] 
[j, k, l]] 

結果應該是:

new_data = [[ad, be,cf] 
[qtm, run, svo] 
[gj, hk, il]] 

這是我的功能,我stucked進步吧。

def _merge_data_cells(table_grid): 
    header, data = table_grid 
    if header is None or data is None: 
     return 
    offset_row = True 
    while offset_row: 
     for i, row in enumerate(data): 
      if is_empty(row): 
       offset_row = False 
       break 
      for cell in row: 

    return header, data 

預先感謝您的幫助。

+2

請閱讀[這些指導方針](https://stackoverflow.com/help/how-to-ask)並告訴我們你有什麼嘗試。如果你向社區表明你已經嘗試了某些東西,那麼你很可能會收到答案。 –

+0

你究竟在做什麼**?字符串? –

+0

@ juanpa.arrivillaga是的,我正在使用字符串 – otje

回答

1

假設你正在處理字符串,使用itertools.groupbyany

In [6]: data = [['a', 'b', 'c'], 
    ...: ['d', 'e', 'f'], 
    ...: ['','',''], 
    ...: ['q', 'r', 's'], 
    ...: ['t', 'u', 'v'], 
    ...: ['m', 'n', 'o'], 
    ...: ['','',''], 
    ...: ['g', 'h', 'i'], 
    ...: ['j', 'k', 'l']] 

In [7]: from itertools import groupby 

In [8]: grouped = groupby(data, any) 

In [9]: [list(map(''.join, zip(*g))) for k, g in grouped if k] 
Out[9]: [['ad', 'be', 'cf'], ['qtm', 'run', 'svo'], ['gj', 'hk', 'il']] 
+0

非常感謝你,它的工作! – otje

0

你可以創建一個使用zipitertools.groupby實現列表理解此爲:

>>> from itertools import groupby 

>>> [[''.join(x) for x in zip(*j)] for i, j in groupby(data, lambda x: x[0]!='') if i] 
[['ad', 'be', 'cf'], ['qtm', 'run', 'svo'], ['gj', 'hk', 'il']] 

其中data變量持有的值:

data = [['a', 'b', 'c'], 
     ['d', 'e', 'f'], 
     ['','',''] 
     ['q', 'r', 's'], 
     ['t', 'u', 'v'], 
     ['m', 'n', 'o'], 
     ['','',''], 
     ['g', 'h', 'i'], 
     ['j', 'k', 'l']]