Joylove
Joylove

Reputation: 414

Product of lists of lists with variable members

Say I have this input data

my_input_list = [[A],[A,B,C],[D],[D,E,F],[A,B,C,D,E,F],[A,C,E]]
items_that_appear_twice = [A,B,C]
items_that_appear_four = [D,E,F]

And I want to create an expansion such that some elements are only allowed to appear twice.

my_output_list = [
[A],[A],
[A,B,C],[A,B,C],
[D],[D],[D],[D],
[D,E,F],[D,E,F],[D,E,F],[D,E,F],
[A,B,C,D,E,F],[A,B,C,D,E,F],[D,E,F],[D,E,F],
[A,C,E],[A,C,E],[E],[E]]

I tired a few ideas and didn't find a really neat solution, like building lists of four and list.remove() from them which generated two empty lists. For example list removal techniques on my_input_list[0]*4 gives [A],[A],[],[] (two empty lists) when I want [A],[A] .

Upvotes: 1

Views: 41

Answers (3)

Sphinx
Sphinx

Reputation: 10729

Below is my solution, sort the sub list first, then append to the result according different situation.

my_input_list = [['A'],['A','B','C'],['D'],['D','E','F'],['A','B','C','D','E','F'],['A','C','E']]
items_that_appear_twice = ['A','B','C']
items_that_appear_four = ['D','E','F']

result = []
for sublist in my_input_list:
    appearence = {1:[], 2:[], 4:[]}
    for item in sublist:
        appearence[2].append(item) if item in items_that_appear_twice else (appearence[4].append(item) if item in items_that_appear_four else appearence[1].append(item))
    if len(appearence[2]) > 0:
        result.append([appearence[2] + appearence[4]] * 2 + ([appearence[4]] * 2 if appearence[4] and len(appearence[4]) > 0 else []))
    else:
        result.append([appearence[4]] * 4)
for item in result:
    print(item)

output:

[['A'], ['A']]
[['A', 'B', 'C'], ['A', 'B', 'C']]
[['D'], ['D'], ['D'], ['D']]
[['D', 'E', 'F'], ['D', 'E', 'F'], ['D', 'E', 'F'], ['D', 'E', 'F']]
[['A', 'B', 'C', 'D', 'E', 'F'], ['A', 'B', 'C', 'D', 'E', 'F'], ['D', 'E', 'F'], ['D', 'E', 'F']]
[['A', 'C', 'E'], ['A', 'C', 'E'], ['E'], ['E']]
[Finished in 0.178s]

Upvotes: 1

raul.vila
raul.vila

Reputation: 1984

I have a working version: See Pyfiddle.

my_input_list = [['A'],['A','B','C'],['D'],['D','E','F'],['A','B','C','D','E','F'],['A','C','E']]
items_that_appear_twice = ['A','B','C']
items_that_appear_four = ['D','E','F']

my_output_list = []
for my_input in my_input_list:
    items_allowed_to_appear_twice = list(filter(
        lambda value: (value in items_that_appear_twice 
                       or value in items_that_appear_four),
        my_input))

    items_allowed_to_appear_four = list(filter(
        lambda value: value in items_that_appear_four,
        my_input))

    my_output_list += 2*[items_allowed_to_appear_twice]
    if len(items_allowed_to_appear_four):
        my_output_list += 2*[items_allowed_to_appear_four]

print(my_output_list)

Upvotes: 2

Alex Hall
Alex Hall

Reputation: 36013

my_input_list = [['A'],
                 ['A', 'B', 'C'],
                 ['D'],
                 ['D', 'E', 'F'],
                 ['A', 'B', 'C', 'D', 'E', 'F'],
                 ['A', 'C', 'E']]
items_that_appear_twice = ['A', 'B', 'C']
items_that_appear_four = ['D', 'E', 'F']

my_output_list = []
for sub in my_input_list:
    my_output_list.append(sub)
    my_output_list.append(sub)
    sub = [x for x in sub if x in items_that_appear_four]
    if sub:
        my_output_list.append(sub)
        my_output_list.append(sub)

assert my_output_list == [
    ['A'], ['A'],
    ['A', 'B', 'C'], ['A', 'B', 'C'],
    ['D'], ['D'], ['D'], ['D'],
    ['D', 'E', 'F'], ['D', 'E', 'F'], ['D', 'E', 'F'], ['D', 'E', 'F'],
    ['A', 'B', 'C', 'D', 'E', 'F'], ['A', 'B', 'C', 'D', 'E', 'F'], ['D', 'E', 'F'], ['D', 'E', 'F'],
    ['A', 'C', 'E'], ['A', 'C', 'E'], ['E'], ['E']]

Upvotes: 1

Related Questions