Проще всего использовать Pandas, как описано Преобразовать список словарей в кадр данных
Код
import pandas as pd
my_dict = [ {'type' : 'type_1', 'prob' : 2, 'x_sum' : 3, 'y_sum' : 5},
{'type' : 'type_2', 'prob' : 3, 'x_sum' : 8, 'y_sum' : 6}]
df = pd.DataFrame(my_dict)
print(df)
Вывод
type prob x_sum y_sum
0 type_1 2 3 5
1 type_2 3 8 6
Без индексного столбца
df_no_indices = df.to_string(index=False)
print(df_no_indices)
Выход
type prob x_sum y_sum
type_1 2 3 5
type_2 3 8 6
Другое Примеры форматов
Источник
Сообщение SQL
from tabulate import tabulate
pdtabulate=lambda df:tabulate(df,headers='keys',tablefmt='psql')
print(pdtabulate(df))
+----+--------+--------+---------+---------+
| | type | prob | x_sum | y_sum |
|----+--------+--------+---------+---------|
| 0 | type_1 | 2 | 3 | 5 |
| 1 | type_2 | 3 | 8 | 6 |
+----+--------+--------+---------+---------+
HTML
pdtabulate=lambda df:tabulate(df,headers='keys',tablefmt='html')
print(pdtabulate(df))
<table>
<thead>
<tr><th style="text-align: right;"> </th><th>type </th><th style="text-align: right;"> prob</th><th style="text-align: right;"> x_sum</th><th style="text-align: right;"> y_sum</th></tr>
</thead>
<tbody>
<tr><td style="text-align: right;"> 0</td><td>type_1</td><td style="text-align: right;"> 2</td><td style="text-align: right;"> 3</td><td style="text-align: right;"> 5</td></tr>
<tr><td style="text-align: right;"> 1</td><td>type_2</td><td style="text-align: right;"> 3</td><td style="text-align: right;"> 8</td><td style="text-align: right;"> 6</td></tr>
</tbody>
</table>