-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGet_Data.py
55 lines (47 loc) · 2.03 KB
/
Get_Data.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
from Read_Data_Image import read_file
from sklearn.model_selection import train_test_split
from keras.utils import np_utils
import random
import csv
from Config import config
# 建立一个用于存储和格式化读取训练数据的类
class DataSet(object):
def __init__(self,path):
self.num_classes = None
self.X_train = None
self.X_test = None
self.Y_train = None
self.Y_test = None
self.img_size = config['image_size']
self.extract_data(path) # 在这个类初始化的过程中读取path下的训练数据
def extract_data(self,path):
# 根据指定路径读取出图片、标签和类别数
imgs,labels,counter,name = read_file(path)
# 将姓名列表写入csv文件
f = open(config['name_list_path'],'w',encoding='utf-8')
csv_writer = csv.writer(f)
csv_writer.writerow(name)
f.close()
# 将数据集打乱随机分组
X_train,X_test,y_train,y_test = train_test_split(imgs,labels,test_size=0.2,random_state=random.randint(0, 100))
# 重新格式化和标准化
X_train = X_train.reshape(X_train.shape[0], self.img_size, self.img_size, 3)/255.0
X_test = X_test.reshape(X_test.shape[0], self.img_size, self.img_size, 3) / 255.0
X_train = X_train.astype('float32')
X_test = X_test.astype('float32')
# 将labels转成 binary class matrices
Y_train = np_utils.to_categorical(y_train, num_classes=counter)
Y_test = np_utils.to_categorical(y_test, num_classes=counter)
# 将格式化后的数据赋值给类的属性上
self.X_train = X_train
self.X_test = X_test
self.Y_train = Y_train
self.Y_test = Y_test
self.num_classes = counter
def check(self):
print('num of dim:', self.X_test.ndim)
print('shape:', self.X_test.shape)
print('size:', self.X_test.size)
print('num of dim:', self.X_train.ndim)
print('shape:', self.X_train.shape)
print('size:', self.X_train.size)