Как я могу написать журнал DEAP в виде текстового файла? - PullRequest
0 голосов
/ 28 июня 2018

Я работаю с DEAP для генетических алгоритмов. Я получил некоторые результаты в бортовом журнале. Журнал имеет свою форму в виде добавления словаря, как показано ниже.

{"gen": 0, "nevals": 200, "avg": 5678.124656362589, "std": 1665.10303246997, "min": 2414.709605862963, "max": 10544.10349270114, "time": 3.061805009841919}
{"gen": 1, "nevals": 200, "avg": 4615.100755434814, "std": 1032.0542912118117, "min": 2414.709605862963, "max": 8710.009719746668, "time": 5.24877405166626}
{"gen": 2, "nevals": 200, "avg": 4426.86753960162, "std": 952.752217081577, "min": 2414.709605862963, "max": 7834.360961929298, "time": 7.716948747634888}
{"gen": 3, "nevals": 200, "avg": 4312.832205468258, "std": 954.6308089644021, "min": 2820.0828681777357, "max": 8069.475022854921, "time": 10.185122013092041}
{"gen": 4, "nevals": 200, "avg": 4333.539783185404, "std": 1155.0262921447736, "min": 2761.1404825322666, "max": 9830.868579904474, "time": 12.684537410736084}
{"gen": 5, "nevals": 200, "avg": 4285.034002752331, "std": 1136.5306484499206, "min": 2571.9258380478823, "max": 10371.549396541837, "time": 15.215197086334229}

Я могу записать это как текстовый файл методом json.dumps. Но я хочу написать это в виде текстового файла, как показано ниже, так же, как результаты на консоли.

результат на консоли Python

Могу ли я справиться с этим?

Сейчас я использую Python 3.6.

1 Ответ

0 голосов
/ 06 июля 2018

Вы можете использовать pandas, чтобы создать DataFrame и записать его в файл CSV.

In [1]: import pandas as pd
In [2]: from deap import tools

In [3]: logbook = tools.Logbook() # Creating a logbook

In [4]: logbook.record(gen=0, nevals=200, avg=5678.124656362589, std=1665.10303246997, 
                       min=2414.709605862963, max=10544.10349270114, time=3.061805009841919)   
In [5]: logbook.record(gen=1, nevals=200, avg=4615.100755434814, std=1032.0542912118117, 
                       min=2414.709605862963, max=8710.009719746668, time=5.24877405166626)    
In [6]: logbook.record(gen=2, nevals=200, avg=4426.86753960162, std=952.752217081577, 
                       min=2414.709605862963, max=7834.360961929298, time=7.716948747634888)

In [7]: df_log = pd.DataFrame(logbook)

In [8]: df_log
Out[8]: 
           avg  gen           max          min  nevals          std      time
0  5678.124656    0  10544.103493  2414.709606     200  1665.103032  3.061805
1  4615.100755    1   8710.009720  2414.709606     200  1032.054291  5.248774
2  4426.867540    2   7834.360962  2414.709606     200   952.752217  7.716949

In [9]: df_log.to_csv('/path/to/your/file.csv', index=False) # Writing to a CSV file
...