数据增强方法,旋转,翻转
import os
from PIL import Image
import argparse
import shutil
parser = argparse.ArgumentParser(description="数据增强")
parser.add_argument("--input-path", type=str, default='增强前的地址', help="地址")
parser.add_argument("--out-path", type=str, default='增强后的保存地址', help="地址")
opt = parser.parse_args()
pathlist = os.listdir(opt.input_path)
if not os.path.exists(opt.out_path):
os.mkdir(opt.out_path)
scale = [1]
angle = [0]
flip = [0, 1, 2, 3, 4, 5, 6]
count = 0
for image_name in pathlist:
image = Image.open(os.path.join(opt.input_path, image_name)).convert('RGB')
for i in range(len(scale)):
for j in range(len(angle)):
for c in range(len(flip)):
image = image.rotate(angle[j])
image = image.resize((int(image.size[0] * scale[i]), int(image.size[1] * scale[i])), Image.BICUBIC)
if flip[c] == 0:
image = image
elif flip[c] == 1:
image = image.transpose(Image.FLIP_LEFT_RIGHT)
elif flip[c] == 2:
image = image.transpose(Image.FLIP_TOP_BOTTOM)
elif flip[c] == 3:
image = image.transpose(Image.ROTATE_90)
elif flip[c] == 4:
image = image.transpose(Image.ROTATE_180)
elif flip[c] == 5:
image = image.transpose(Image.ROTATE_270)
else:
image = image.transpose(Image.TRANSPOSE)
count += 1
aa = image_name.split('.')[0] + '{}_{}_{}.jpg'.format(i, j, c)
image.save(os.path.join(opt.out_path, aa))
image = Image.open(os.path.join(opt.input_path, image_name)).convert('RGB')