Reputation: 189
I have a list of lists that looks like this. I would like to remove the inner list, and keep the outer list. I do NOT want to flatten the entire thing into a giant list of elements.
['100', ['ADDRESS', 'START', '100']]
['. TESTS PC FORWARD ADDRESSING']
['. TESTS BASE ADDRESSING']
['. TESTS PC BACKWARD ADDRESSING']
['100', ['NOW', '+LDB', '#BEGIN', 'load base register']]
['104', ['XXX', 'BASE', 'BEGIN', 'tell assembler']]
['104', ['YYY', 'LDA', 'BE', 'A <- (m..m+2)']]
['107', ['EN', 'RESW', '4']]
['113', ['BE', 'WORD', '2']]
['116', ['BEGIN', 'RESW', '1']]
['119', ['JUNK', 'RESW', '2200']]
['1ae1', ['THERE', 'RESW', '1']]
['1ae4', ['ZZZ', 'LDA', 'JUNK']]
['1ae7', ['MMM', 'STA', 'THERE']]
['1aea', ['', 'END', 'NOW']]
What I want is this:
['100', 'ADDRESS', 'START', '100']
['. TESTS PC FORWARD ADDRESSING']
['. TESTS BASE ADDRESSING']
['. TESTS PC BACKWARD ADDRESSING']
['100', 'NOW', '+LDB', '#BEGIN', 'load base register']
['104', 'XXX', 'BASE', 'BEGIN', 'tell assembler']
['104', 'YYY', 'LDA', 'BE', 'A <- (m..m+2)']
['107', 'EN', 'RESW', '4']
['113', 'BE', 'WORD', '2']
['116', 'BEGIN', 'RESW', '1']
['119', 'JUNK', 'RESW', '2200']
['1ae1', 'THERE', 'RESW', '1']
['1ae4', 'ZZZ', 'LDA', 'JUNK']
['1ae7', 'MMM', 'STA', 'THERE']
['1aea', '', 'END', 'NOW']
My code:
newlist = [str(sublist[0]) + str(sublist[1:]) for sublist in final_file]
This code gives me this output, not exactly what I want:
100[['ADDRESS', 'START', '100']]
. TESTS PC FORWARD ADDRESSING[]
. TESTS BASE ADDRESSING[]
. TESTS PC BACKWARD ADDRESSING[]
100[['NOW', '+LDB', '#BEGIN', 'load base register']]
104[['XXX', 'BASE', 'BEGIN', 'tell assembler']]
104[['YYY', 'LDA', 'BE', 'A <- (m..m+2)']]
107[['EN', 'RESW', '4']]
113[['BE', 'WORD', '2']]
116[['BEGIN', 'RESW', '1']]
119[['JUNK', 'RESW', '2200']]
1ae1[['THERE', 'RESW', '1']]
1ae4[['ZZZ', 'LDA', 'JUNK']]
1ae7[['MMM', 'STA', 'THERE']]
1aea[['', 'END', 'NOW']]
Upvotes: 1
Views: 698
Reputation: 81
If the list in question is;
a = [
['100', ['ADDRESS', 'START', '100']],
['. TESTS PC FORWARD ADDRESSING'],
['. TESTS BASE ADDRESSING'],
['. TESTS PC BACKWARD ADDRESSING'],
['100', ['NOW', '+LDB', '#BEGIN', 'load base register']],
['104', ['XXX', 'BASE', 'BEGIN', 'tell assembler']],
['104', ['YYY', 'LDA', 'BE', 'A <- (m..m+2)']],
['107', ['EN', 'RESW', '4']],
['113', ['BE', 'WORD', '2']],
['116', ['BEGIN', 'RESW', '1']],
['119', ['JUNK', 'RESW', '2200']],
['1ae1', ['THERE', 'RESW', '1']],
['1ae4', ['ZZZ', 'LDA', 'JUNK']],
['1ae7', ['MMM', 'STA', 'THERE']],
['1aea', ['', 'END', 'NOW']],
]
A one-liner:
[sum([sub if isinstance(sub, list) else [sub] for sub in x], []) for x in a]
If you want it for just the individual lists, then remove the outer loop;
sum([sub if isinstance(sub, list) else [sub] for sub in a[0]], [])
Upvotes: 1
Reputation: 422
newlist = ['104', ['YYY', 'LDA', 'BE', 'A <- (m..m+2)']]
final = []
for n in newlist:
if type(n) == list:
for i in n:
final.append(i)
else:
final.append(n)
print(final)
You can check if the type of the element is list, if yes then use another loop to unpack it and append it to a new list.
Upvotes: 0
Reputation: 14226
Here is a simple for-loop approach to give you a generic approach.
def unpacker(lists):
for list_ in lists:
o = []
for item in list_:
if isinstance(item, list):
for i in item:
o.append(i)
else:
o.append(item)
yield o
Then you call it --> list(unpacker(l))
Upvotes: 3
Reputation: 189
UPDATE:
newlist = [[x[0]] + x[1] if len(x) >= 2 else x for x in final_file]
This works
Upvotes: 1