In this tutorial, we'll walk through creating a generative AI chatbot using Python and the OpenAI API. We'll build a chatbot that can engage in natural conversations while maintaining context and providing helpful responses.
Prerequisites
- Python 3.8+
- Basic understanding of Python programming
- OpenAI API key
- Basic knowledge of RESTful APIs
Setting Up the Environment
First, let's set up our development environment. Create a new Python project and install the required dependencies:
pip install openai python-dotenv streamlit
Project Structure
Our chatbot will have a clean, modular structure:
chatbot/ ├── .env ├── app.py ├── chat_handler.py └── requirements.txt
Implementation
Let's start with our core chatbot logic in chat_handler.py
:
import openai from typing import List, Dict import os from dotenv import load_dotenv load_dotenv() class ChatBot: def __init__(self): openai.api_key = os.getenv("OPENAI_API_KEY") self.conversation_history: List[Dict[str, str]] = [] self.system_prompt = """You are a helpful AI assistant. Provide clear, accurate, and engaging responses while maintaining a friendly tone.""" def add_message(self, role: str, content: str): self.conversation_history.append({"role": role, "content": content}) def get_response(self, user_input: str) -> str: # Add user input to conversation history self.add_message("user", user_input) # Prepare messages for API call messages = [{"role": "system", "content": self.system_prompt}] + \ self.conversation_history try: # Make API call to OpenAI response = openai.ChatCompletion.create( model="gpt-3.5-turbo", messages=messages, max_tokens=1000, temperature=0.7 ) # Extract and store assistant's response assistant_response = response.choices[0].message.content self.add_message("assistant", assistant_response) return assistant_response except Exception as e: return f"An error occurred: {str(e)}"
Now, let's create a simple web interface using Streamlit in app.py
:
import streamlit as st from chat_handler import ChatBot def main(): st.title("🤖 AI Chatbot") # Initialize session state if "chatbot" not in st.session_state: st.session_state.chatbot = ChatBot() # Chat interface if "messages" not in st.session_state: st.session_state.messages = [] # Display chat history for message in st.session_state.messages: with st.chat_message(message["role"]): st.write(message["content"]) # Chat input if prompt := st.chat_input("What's on your mind?"): # Add user message to chat history st.session_state.messages.append({"role": "user", "content": prompt}) with st.chat_message("user"): st.write(prompt) # Get bot response response = st.session_state.chatbot.get_response(prompt) # Add assistant response to chat history st.session_state.messages.append({"role": "assistant", "content": response}) with st.chat_message("assistant"): st.write(response) if __name__ == "__main__": main()
Key Features
- Conversation Memory: The chatbot maintains context by storing the conversation history.
- System Prompt: We define the chatbot's behavior and personality through a system prompt.
- Error Handling: The implementation includes basic error handling for API calls.
- User Interface: A clean, intuitive web interface using Streamlit.
Running the Chatbot
- Create a
.env
file with your OpenAI API key:
OPENAI_API_KEY=your_api_key_here
- Run the application:
streamlit run app.py
Potential Enhancements
- Conversation Persistence: Add database integration to store chat histories.
- Custom Personalities: Allow users to select different chatbot personalities.
- Input Validation: Add more robust input validation and sanitization.
- API Rate Limiting: Implement rate limiting to manage API usage.
- Response Streaming: Add streaming responses for better user experience.
Conclusion
This implementation demonstrates a basic but functional generative AI chatbot. The modular design makes it easy to extend and customize based on specific needs. While this example uses OpenAI's API, the same principles can be applied with other language models or APIs.
Remember that when deploying a chatbot, you should consider:
- API costs and usage limits
- User data privacy and security
- Response latency and optimization
- Input validation and content moderation
Top comments (1)
Nice!