Allunga le colonne per accoppiare le celle corrispondenti nelle righe
Domanda
Tabella di esempio:
A | B | C | ...
-----+-----+-----+----
3 | 2 | 2 |
5 | 3 | 4 |
7 | 4 | 6 |
9 | 5 | 8 |
Vorrei in qualche modo temperarlo con Gnumeric e produrre celle corrispondenti su colonne:
A | B | C | ...
-----+-----+-----+----
- | 2 | 2 |
3 | 3 | - |
- | 4 | 4 |
5 | 5 | - |
- | - | 6 |
7 | - | - |
- | - | 8 |
9 | - | - |
Esempio reale se con valori stringa invece numeri ma è più facile da spiegare con numeri credo
Se questo non è banale e qualcuno ha idea di come farlo con gli elenchi Python invece di colonne di tabella in Gnumeric, invia una soluzione Python.
Soluzione
È abbastanza facile da fare in Python:
a = [3, 5, 7, 9]
b = [2, 3, 4, 5]
c = [2, 4, 6, 8]
a_ex, b_ex, c_ex = zip(*(
[elem if elem in col else None
for col in a, b, c]
for elem in set(a).union(b, c)
))
Sembra il più diretto se non sei preoccupato per la velocità.
Ho anche appena notato la mia risposta a Unione di più iteratori con una chiave si applica:
def paditers(*args):
iters = [iter(x) for x in args]
this = [next(i) for i in iters]
while True:
try:
key = min(i for i in this if i != None)
except ValueError:
break
for i, val in enumerate(this):
if val == key:
yield val
this[i] = next(iters[i], None)
else:
yield None
padded = list(paditers(a, b, c))
next_item = iter(padded).next
print zip(*((next_item(), next_item(), next_item())
for _ in range(len(padded) // 3)))
Puoi adattarlo se hai bisogno di una scalabilità lineare delle prestazioni.
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow