Files
julius_baer_onboarding/utils/parsers/passport_parser.py

39 lines
1.3 KiB
Python
Raw Normal View History

2025-04-13 10:36:29 +02:00
import base64
import io
from PIL import Image
from langchain_openai import ChatOpenAI
from langchain.output_parsers import PydanticOutputParser
from langchain_core.prompts import ChatPromptTemplate
from validation.from_passport import FromPassport
2025-04-12 10:51:07 +02:00
2025-04-13 10:03:32 +02:00
def process_passport(passport_b64: str) -> str:
2025-04-13 10:36:29 +02:00
"""
Traite le passport :
- Décodage de l'image en base64.
- Envoi à GPT-4o avec un prompt d'extraction structuré.
- Parsing structuré avec un modèle Pydantic.
2025-04-13 10:36:29 +02:00
"""
image_bytes = base64.b64decode(passport_b64)
image = Image.open(io.BytesIO(image_bytes))
# Parser structuré basé sur le modèle FromPassport
parser = PydanticOutputParser(pydantic_object=FromPassport)
# Prompt + Instructions pour extraction
prompt = ChatPromptTemplate.from_messages([
("system", "Tu es un assistant d'extraction de données de passeport."),
("human", "Voici l'image d'un passeport. Extrais les informations dans ce format :\n\n{format_instructions}"),
])
# LLM avec vision (GPT-4o)
llm = ChatOpenAI(model="gpt-4o", temperature=0)
chain = prompt | llm.with_structured_output(parser=parser)
# Appel du LLM avec l'image en contexte
result = chain.invoke({
"format_instructions": parser.get_format_instructions(),
"image": image,
})
return result.json()