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
from utils.tools import save_dict, load_dict

sbp_index = 499
dbp_index = 500

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()

def read_label(f_list, path_root):
    labels = []
    for f in f_list:
        f_pth = os.path.join(path_root,f)
        data = load_dict(f_pth)
        label_s = data[0, sbp_index]
        label_d = data[0, dbp_index]
        labels.append((label_s, label_d))
    return labels


if __name__ == "__main__":
    # data_path = "E:/Datasets/Target/BloodPressure/"
    # savename = "BloodPressure"
    # users = [str(i) for i in range(10)]
    # dict = {}
    # dict_label = {}
    # for u in users:
    #     user_dict = {}
    #     user_label_dict = {}
    #     user_path = osp.join(data_path, u)
    #     f_list = [osp.join(u, l).replace(os.sep, '/') for l in listdir(user_path)]
    #     label = read_label(f_list, data_path)
    #     user_dict[int(0)] = f_list
    #     user_label_dict[int(0)] = label
    #     dict[str(u)] = user_dict
    #     dict_label[str(u)] = user_label_dict
    #
    # all_dict= {}
    # all_dict['data'] = dict
    # all_dict['label'] = dict_label
    # # write summary file
    # statistic_user_data(dict, file='{}_summary.txt'.format(savename))
    #
    # # write pkl file
    # save_dict(all_dict, '{}.pkl'.format(savename))

    # test
    savename = "BloodPressure"
    load_file = load_dict('{}.pkl'.format(savename))
    print()
