top of page

Building a Multi-Language Invoice Extractor Using Generative AI

Writer's picture: Revanth Reddy TondapuRevanth Reddy Tondapu

Multi-Language Invoice Extractor Using Generative AI
Multi-Language Invoice Extractor Using Generative AI

Hello All, In this blog, we are going to create a multi-language invoice extractor application using Generative AI. The goal is to develop an app that can handle invoices in various languages, extract relevant information, and provide responses to user queries. This project will involve setting up the environment, installing necessary libraries, and writing the code step-by-step.


Agenda

  1. Setting Up the Environment

  2. Creating the Requirements File

  3. Writing the Code Step-by-Step

  4. Additional Improvements and Considerations


Let's start by discussing the functionality of our final product. The app will allow users to upload invoices in different languages. Using a powerful Generative AI API, it will extract specific information based on user queries. For example, if an invoice is in Telugu or Hindi and you ask for the address, the app will extract and display the address from the invoice.


Setting Up the Environment

First, we need to set up a virtual environment to ensure our project dependencies do not interfere with other projects.

conda create -n invoice_extractor_env python=3.10
conda activate invoice_extractor_env

Next, create a .env file to store your API key:

GOOGLE_API_KEY=your_api_key_here

Creating the Requirements File

Create a requirements.txt file with the following content:

streamlit
google-generativeai
python-dotenv
langchain
PyPDF2
chromadb
faiss-cpu

Install the dependencies:

pip install -r requirements.txt

Writing the Code Step-by-Step

Now, let’s start writing the code. Create a file named app.py and add the following code:

Import Libraries and Load Environment Variables

import streamlit as st
from dotenv import load_dotenv
import os
from PIL import Image
import google.generativeai as genai

# Load environment variables from .env file
load_dotenv()
genai.configure(api_key=os.getenv("GOOGLE_API_KEY"))

Function to Load the Generative AI Model and Get Responses

def get_gemini_response(input_prompt, image, user_prompt):
    model = genai.GenerativeModel('gemini-pro-vision')
    response = model.generate_content([input_prompt, image[0], user_prompt])
    return response.text

Function to Process the Uploaded Image

def input_image_setup(uploaded_file):
    if uploaded_file is not None:
        bytes_data = uploaded_file.getvalue()
        image_parts = [
            {
                "mime_type": uploaded_file.type,
                "data": bytes_data
            }
        ]
        return image_parts
    else:
        raise FileNotFoundError("No file uploaded")

Streamlit App Setup

# Initialize Streamlit app
st.set_page_config(page_title="Multi-Language Invoice Extractor")
st.header("Multi-Language Invoice Extractor")

# Input prompt for the AI model
input_prompt = """
               You are an expert in understanding invoices.
               You will receive input images as invoices &
               you will have to answer questions based on the input image.
               """

# User input and file uploader
user_prompt = st.text_input("Ask a question about the invoice:")
uploaded_file = st.file_uploader("Choose an invoice image...", type=["jpg", "jpeg", "png"])

if uploaded_file is not None:
    image = Image.open(uploaded_file)
    st.image(image, caption="Uploaded Invoice Image", use_column_width=True)

# Submit button
submit = st.button("Extract Information")

# If submit button is clicked, process the image and get the response
if submit and uploaded_file is not None:
    image_data = input_image_setup(uploaded_file)
    response = get_gemini_response(input_prompt, image_data, user_prompt)
    st.subheader("Extracted Information")
    st.write(response)

Additional Improvements and Considerations

While the basic functionality is now in place, there are several improvements and additional features you could consider:

  1. Error Handling: Add more robust error handling to manage issues like unsupported file types or missing API keys.

  2. Multi-Page Support: Enhance the app to handle multi-page invoices.

  3. Language Detection: Automatically detect the language of the invoice and adjust the prompts accordingly.

  4. Database Integration: Store extracted information in a database for further analysis and reporting.

  5. UI/UX Enhancements: Improve the user interface for better user experience, perhaps by adding more descriptive labels or progress indicators.

Running the Application

To start the application, run the following command:

streamlit run app.py

This will open a web interface where you can upload invoice images, ask questions about them, and get responses using the Generative AI model.


Conclusion

Congratulations! You've built a complete end-to-end multi-language invoice extractor using Generative AI. This project showcases how powerful AI can be in automating the extraction of information from complex documents, making it a valuable tool for businesses of all sizes.

If you have any questions or suggestions, feel free to leave a comment. Happy coding! 

9 views0 comments

Comments


bottom of page