Movatterモバイル変換


[0]ホーム

URL:


Skip to main content
OurBuilding Ambient Agents with LangGraph course is now available on LangChain Academy!
Open In ColabOpen on GitHub

OpenAI metadata tagger

It can often be useful to tag ingested documents with structured metadata, such as the title, tone, or length of a document, to allow for a more targeted similarity search later. However, for large numbers of documents, performing this labelling process manually can be tedious.

TheOpenAIMetadataTagger document transformer automates this process by extracting metadata from each provided document according to a provided schema. It uses a configurableOpenAI Functions-powered chain under the hood, so if you pass a custom LLM instance, it must be anOpenAI model with functions support.

Note: This document transformer works best with complete documents, so it's best to run it first with whole documents before doing any other splitting or processing!

For example, let's say you wanted to index a set of movie reviews. You could initialize the document transformer with a validJSON Schema object as follows:

from langchain_community.document_transformers.openai_functionsimport(
create_metadata_tagger,
)
from langchain_core.documentsimport Document
from langchain_openaiimport ChatOpenAI
schema={
"properties":{
"movie_title":{"type":"string"},
"critic":{"type":"string"},
"tone":{"type":"string","enum":["positive","negative"]},
"rating":{
"type":"integer",
"description":"The number of stars the critic rated the movie",
},
},
"required":["movie_title","critic","tone"],
}

# Must be an OpenAI model that supports functions
llm= ChatOpenAI(temperature=0, model="gpt-3.5-turbo-0613")

document_transformer= create_metadata_tagger(metadata_schema=schema, llm=llm)

You can then simply pass the document transformer a list of documents, and it will extract metadata from the contents:

original_documents=[
Document(
page_content="Review of The Bee Movie\nBy Roger Ebert\n\nThis is the greatest movie ever made. 4 out of 5 stars."
),
Document(
page_content="Review of The Godfather\nBy Anonymous\n\nThis movie was super boring. 1 out of 5 stars.",
metadata={"reliable":False},
),
]

enhanced_documents= document_transformer.transform_documents(original_documents)
import json

print(
*[d.page_content+"\n\n"+ json.dumps(d.metadata)for din enhanced_documents],
sep="\n\n---------------\n\n",
)
Review of The Bee Movie
By Roger Ebert

This is the greatest movie ever made. 4 out of 5 stars.

{"movie_title": "The Bee Movie", "critic": "Roger Ebert", "tone": "positive", "rating": 4}

---------------

Review of The Godfather
By Anonymous

This movie was super boring. 1 out of 5 stars.

{"movie_title": "The Godfather", "critic": "Anonymous", "tone": "negative", "rating": 1, "reliable": false}

The new documents can then be further processed by a text splitter before being loaded into a vector store. Extracted fields will not overwrite existing metadata.

You can also initialize the document transformer with a Pydantic schema:

from typingimport Literal

from pydanticimport BaseModel, Field


classProperties(BaseModel):
movie_title:str
critic:str
tone: Literal["positive","negative"]
rating:int= Field(description="Rating out of 5 stars")


document_transformer= create_metadata_tagger(Properties, llm)
enhanced_documents= document_transformer.transform_documents(original_documents)

print(
*[d.page_content+"\n\n"+ json.dumps(d.metadata)for din enhanced_documents],
sep="\n\n---------------\n\n",
)
Review of The Bee Movie
By Roger Ebert

This is the greatest movie ever made. 4 out of 5 stars.

{"movie_title": "The Bee Movie", "critic": "Roger Ebert", "tone": "positive", "rating": 4}

---------------

Review of The Godfather
By Anonymous

This movie was super boring. 1 out of 5 stars.

{"movie_title": "The Godfather", "critic": "Anonymous", "tone": "negative", "rating": 1, "reliable": false}

Customization

You can pass the underlying tagging chain the standard LLMChain arguments in the document transformer constructor. For example, if you wanted to ask the LLM to focus specific details in the input documents, or extract metadata in a certain style, you could pass in a custom prompt:

from langchain_core.promptsimport ChatPromptTemplate

prompt= ChatPromptTemplate.from_template(
"""Extract relevant information from the following text.
Anonymous critics are actually Roger Ebert.

{input}
"""
)

document_transformer= create_metadata_tagger(schema, llm, prompt=prompt)
enhanced_documents= document_transformer.transform_documents(original_documents)

print(
*[d.page_content+"\n\n"+ json.dumps(d.metadata)for din enhanced_documents],
sep="\n\n---------------\n\n",
)
API Reference:ChatPromptTemplate
Review of The Bee Movie
By Roger Ebert

This is the greatest movie ever made. 4 out of 5 stars.

{"movie_title": "The Bee Movie", "critic": "Roger Ebert", "tone": "positive", "rating": 4}

---------------

Review of The Godfather
By Anonymous

This movie was super boring. 1 out of 5 stars.

{"movie_title": "The Godfather", "critic": "Roger Ebert", "tone": "negative", "rating": 1, "reliable": false}

[8]ページ先頭

©2009-2025 Movatter.jp