Issue
I am trying to use multiple list of lists to add rows to a dataframe.
The error is as follows: IndexError: invalid index to scalar variable.
The code is below:
List_a = [[1,2,3],[4,5,6],[7,8,9],[10,11,12],[13,14,15]]
List_b = [[16,17,18],[19,20,21],[22,23,24],[25,26,27],[28,29,30]]
List_c = [[31,32,33],[34,35,36],[37,38,39],[40,41,42],[43,44,45]]
Some_List = ['0', '1', '2', '3', '4']
first_row = {'A': [0], 'B': [0], 'C': [0]}
All_Rows = pd.DataFrame(first_row)
#Optimized_Trades
for i in range(len(Some_List)):
for j in range(len(Some_List[i])):
df_temp = { 'A': List_a[i][j], 'B': List_b[i][j], 'C': List_c[i][j]}
All_Rows = All_Rows.append(df_temp, ignore_index = True)
All_Trades = All_Trades[1:]
display(All_Trades)
Ideally, the final output would be:
A B C
1 16 31
2 17 32
3 18 33
4 19 34
5 20 35
6 21 36
7 22 37
8 23 38
9 24 39
10 25 40
11 26 41
12 27 42
13 28 43
14 29 44
15 30 45
Solution
You can use itertools.chain
to flatten each list, construct a dictionary with the flattened lists and cast it to a DataFrame:
from itertools import chain
A, B, C = [list(chain.from_iterable(lst)) for lst in [List_a, List_b, List_c]]
out = pd.DataFrame({'A': A, 'B': B, 'C': C})
Output:
A B C
0 1 16 31
1 2 17 32
2 3 18 33
3 4 19 34
4 5 20 35
5 6 21 36
6 7 22 37
7 8 23 38
8 9 24 39
9 10 25 40
10 11 26 41
11 12 27 42
12 13 28 43
13 14 29 44
14 15 30 45
Answered By - enke
0 comments:
Post a Comment
Note: Only a member of this blog may post a comment.