import csv

from app import Config

csv.register_dialect('custom', doublequote=False, quoting=csv.QUOTE_NONE)


def logEvent(file, row):
    try:
        file_path = 'D:/SYS/Code/CrowdNav_New/app/data/' + str(file) + '_' + str(Config.formatted_datetime) + '.csv'
        with open(file_path, 'a', newline='', encoding='utf-8') as mycsvfile:
            writer = csv.writer(mycsvfile)
            writer.writerow(row)
    except:
        pass

#     with open('E:/SYS/CrowdNav/app/data/' + str(file) + '_' + str(Config.formatted_datetime) + '.csv', 'a', encoding='utf-8') as mycsvfile:
#         writer = csv.writer(mycsvfile, dialect='excel')
#         # print(type(row))
#         writer.writerow(row)
#         # writer.writerow([s.encode('utf-8') for s in row])


# [tick, self.sourceID, self.targetID, durationForTrip,
# minimalCosts, tripOverhead, self.id, self.currentRouterResult.isVictim]
# tick: 时间
# targetID: the target node this car drives to
# sourceID: the source node this car is coming from
# durationForTrip: 计算当前行程的持续时间
# minimalRoute: 记录两点之间最短
# minimalCosts: 用来表示计算得到的最小路径代价的变量（minimalRoute/最大速度）
# tripOverhead: 在代码中，tripOverhead用于记录行程的额外耗时。
# 一旦找到了最小路径（通过minimalRoute函数计算），tripOverhead被用来计算车辆行驶这条最小路径所需的额外时间。
# 这个额外时间可能是由于交通、道路状况或其他不可预见的因素引起的。
# 通过记录和计算额外耗时，我们可以对车辆的行程进行更全面的评估。
# 在实际场景中，了解额外耗时可以帮助智能系统更准确地预测到达时间，提高行驶效率，并且为规划未来行程提供更好的决策支持。
# 因此，tripOverhead在整个代码中扮演着衡量额外行程耗时的重要角色，有助于优化行程规划和车辆调度。
# id: the car id
# currentRouterResult.isVictim: 当路由结果受到了临时的交通阻塞、道路损坏或其他突发事件的影响时，
# 可以将isVictim设置为True，以便系统在后续处理中对受影响的路由结果进行特殊处理或重新规划

# tick, targetID, sourceID, durationForTrip  ,minimalCosts      ,tripOverhead    ,  self.id, self.currentRouterResult.isVictim
# 201,  3186,     3206,     154,              71.65423569641544, 1.9538272739821243, 22767,  False
# 202,  2465,     2856,     181,              91.33408479971123, 1.8015777451133421, 73633,  False
