我有一个存储所有用户ID和名称的人组。我查看了有关人脸 API 的 azure 文档,但我没有得到任何根据人脸 ID 显示名称的内容。不久之前,我曾经将名称和 id 存储在与我过去显示名称的位置不同的 python 文件中。但后来我认为我们已经将名称和 id 存储在 azure 中,为什么要创建另一个文件并将数据存储 2 次,而不是直接从人脸 API 显示名称。谁能指导我如何用id显示名字?
def face_identify(faceId):
global person
KEY = parser.get('AzCognitiveServices','Ocp-Apim-Subscription-Key')
headers = {
# Request headers
'Content-Type': 'application/json',
'Ocp-Apim-Subscription-Key': KEY,
}
params = urllib.urlencode({
})
if faceId is None:
person = ""
return
group = parser.get('AzCognitiveServices','PersonGroupId')
candidatesreturned = list(parser.get('AzCognitiveServices','maxNumOfCandidatesReturned'))
threshold = parser.get('AzCognitiveServices','confidenceThreshold')
body = "{'personGroupId' : '" + group + "','faceIds' : [%s],'maxNumOfCandidatesReturned' : 1,'confidenceThreshold': 0.5}" % str("'%s'"%faceId)
logger.info(body)
try:
uri_base = parser.get('AzCognitiveServices','BaseURL')
path_to_face_api = "/face/v1.0/identify"
response = requests.post(uri_base + path_to_face_api,
data=body,
headers=headers,
params=params,timeout=int(parser.get('AzCognitiveServices','Timeout')))
#response = conn.getresponse()
data = response.json()
logger.info('face id %s',data)
candidates = data[0]["candidates"]
if len(candidates) > 0:
person = str(candidates[0]["personId"])
else:
person = ""
print(person)
except Exception as e:
print("[Errno {0}] {1}".format(e.errno, e.strerror))
如果您在创建这些项目时存储人员的姓名,则只需在找到人员后通过 id 获取 PersonGroup。
所以在你的代码中,它就在这一步:
person = str(candidates[0]["personId"])
在这里,您有找到的人的 personId。将其与 PersonGroup Person 中的 GET 方法一起使用,请参阅此处的文档。它需要您的 PersonGroupId 和 PersonId。
您将检索您要查找的名称