1 回答
TA贡献1898条经验 获得超8个赞
您可以使用数组而不是将每个图像/编码存储在单个变量中,并从for循环中填充数组。
假设您可以将文件名从first.jpg, second.jpg...更改为1.jpg, 2.jpg... 您可以这样做:
numberofimages = 10 # change this to the total number of images
images = [None] * (numberofimages+1) # create an array to store all the images
encodings = [None] * (numberofimages+1) # create an array to store all the encodings
for i in range(1, numberofimages+1):
filename = str(i) + ".jpg" # generate image file name (eg. 1.jpg, 2.jpg...)
# load the image and store it in the array
images[i] = face_recognition.load_image_file(filename)
# store the encoding
encodings[i] = face_recognition.face_encodings(images[i])[0]
然后您可以访问例如。第三张图像和第三个编码是这样的:
image[3]
encoding[3]
如果无法更改图像文件名,您可以将它们存储在字典中并执行以下操作:
numberofimages = 3 # change this to the total number of images
images = [None] * (numberofimages+1) # create an array to store all the images
encodings = [None] * (numberofimages+1) # create an array to store all the encodings
filenames = {
1: "first",
2: "second",
3: "third"
}
for i in range(1, numberofimages+1):
filename = filenames[i] + ".jpg" # generate file name (eg. first.jpg, second.jpg...)
print(filename)
# load the image and store it in the array
images[i] = face_recognition.load_image_file(filename)
# store the encoding
encodings[i] = face_recognition.face_encodings(images[i])[0]
添加回答
举报
