forked from joeyzhou98/CopTheLook
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvision_script.py
executable file
·69 lines (45 loc) · 2.24 KB
/
vision_script.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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
from typing import List
from google.cloud import vision
import os
# set path to api key here
""" INPUT PATH TO JSON API KEY"""
os.environ["GOOGLE_APPLICATION_CREDENTIALS"]="g_credentials.json"
uri = "https://media.endclothing.com/media/catalog/product/0/6/06-12-2017_adidas_ultraboost_coreblack_bb6166_mg_1.jpg"
uri2 = "https://static.nike.com/a/images/t_PDP_864_v1/f_auto,b_rgb:f5f5f5/gsuin11ptg5qgktmzoat/air-force-1-07-shoe-KyTDGepj.jpg"
# detect_web_uri(uri)
def best_match_uri(uri):
""" find best matching product from the given uri and returns best match and additional searches """
client = vision.ImageAnnotatorClient()
image = vision.Image()
image.source.image_uri = uri
response = client.web_detection(image=image)
annotations = response.web_detection
best_web_entity = annotations.web_entities[0]
best_matching_pages = annotations.pages_with_matching_images[0]
result = {}
result['best_web_entity'] = best_web_entity
result['best_matching_pages'] = annotations.pages_with_matching_images
return result
def best_match_uploaded_img(img):
"""Detects web annotations given an image."""
from google.cloud import vision
client = vision.ImageAnnotatorClient()
# with io.open(path, 'rb') as image_file:
# content = image_file.read()
image = vision.Image(content=img)
response = client.web_detection(image=image)
annotations = response.web_detection
urls: List[str] = []
if annotations.pages_with_matching_images:
urls.extend([page.url for page in annotations.pages_with_matching_images])
if annotations.visually_similar_images:
urls.extend([image.url for image in annotations.visually_similar_images])
return urls
# best_web_entity = best_match_uri(uri)['best_web_entity']
# best_matching_pages = best_match_uri(uri)['best_matching_pages']
# print("The product is " , best_web_entity.description , " with a score of " , best_web_entity.score)
# print("You can find it here ", best_matching_pages[0].url)
# print("\nIf that was not the exact product, here are" , str(len(best_matching_pages)) ," additional searches:\n")
# for item in best_matching_pages:
# print('\n' , item.page_title, ':' , item.url, '\n')
# detect_web('images/woman_fashion.jpg')