import enum
import numpy as np
from os import listdir
from os.path import isfile, isdir, join
import os
import os.path as osp
import json
import random
from collections import defaultdict
from six.moves import cPickle as pickle


def save_dict(di_, filename_):
    with open(filename_, 'wb') as f:
        pickle.dump(di_, f)


def load_dict(filename_):
    with open(filename_, 'rb') as f:
        ret_di = pickle.load(f)
    return ret_di


def statistic_user_data(dict, file):
    f = open(file, 'w')
    for uname, item in dict.items():
        n_cls = {}
        for cl, data in item.items():
            n_cls[cl] = len(data)

        f.write('User_{}-> {}\n'.format(uname, n_cls))
    f.close()


if __name__ == "__main__":

    data_path = "D:\Dataset\HybridCrossDataset\Datasets\Target\WESAD"
    savename = "WESAD"

    dict = {}

    users = ['S2', 'S3', 'S4', 'S5', 'S6', 'S7', 'S8', 'S9', 'S10','S11', 'S13', 'S14','S15', 'S16', 'S17']

    for i, u in enumerate(users):
        user_dict = {}
        user_path = osp.join(data_path, u)
        for l in listdir(user_path):
            if isdir(join(user_path, l)):
                folder_path = osp.join(user_path, l)
                f_list = [osp.join(u, l, iname).replace(os.sep, '/') for iname in listdir(folder_path)]
                user_dict[int(l)] = f_list
        dict[str(i)] = user_dict
        print(u,i)

    # write summary file
    statistic_user_data(dict, file='{}_summary.txt'.format(savename))

    # write pkl file
    save_dict(dict, '{}.pkl'.format(savename))

    # test
    load_file = load_dict('{}.pkl'.format(savename))
    print()