-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdbsetup.py
95 lines (65 loc) · 2.41 KB
/
dbsetup.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
import pandas as pd
MAX_TEXT_LENGTH=1000 # Maximum num of text characters to use
from langchain_community.embeddings import OpenAIEmbeddings
from langchain.vectorstores.redis import RedisVectorStore
MAX_TEXT_LENGTH = 1000 # Maximum num of text characters to use
NUMBER_PRODUCTS = 1000 # Num products to use (subset)
OPENAI_API_KEY =os.environ["OPEN_API"] # OpenAI API Key
INDEX_NAME = "products" # Name of the Redis search index to create
REDIS_URL = "redis://localhost:6379" # Redis URL
def auto_truncate(val):
"""Truncate the given text."""
return val[:MAX_TEXT_LENGTH]
# Load Product data and truncate long text fields
all_prods_df = pd.read_csv("sampledata.csv", converters={
'description': auto_truncate,
'product_specifications': auto_truncate,
'product_name': auto_truncate,
'product_category_tree': auto_truncate,
})
# %%
# Replace empty strings with None and drop
all_prods_df['product_specifications'].replace('', None, inplace=True)
all_prods_df.dropna(subset=['product_specifications'], inplace=True)
# Reset pandas dataframe index
all_prods_df.reset_index(drop=True, inplace=True)
# %%
# Num products to use (subset)
NUMBER_PRODUCTS = 1000
# Get the first 1000 products
product_metadata = (
all_prods_df
.head(NUMBER_PRODUCTS)
.to_dict(orient='index')
)
# Check one of the products
product_metadata[0]
# %%
import os
from langchain.embeddings import OpenAIEmbeddings
from langchain.vectorstores.redis import Redis as RedisVectorStore
# set your openAI api key as an environment variable
os.environ['OPENAI_API_KEY'] = os.getenv('OPENAI_API')
# data that will be embedded and converted to vectors
texts = [
v['product_name'] for k, v in product_metadata.items()
]
# Set OpenAI API key as an environment variable
os.environ['OPENAI_API_KEY'] = 'your-api'
os.environ['OPENAI_API_KEY'] = OPENAI_API_KEY
# product metadata that we'll store along our vectors
metadatas = list(product_metadata.values())
# we will use OpenAI as our embeddings provider
embedding = OpenAIEmbeddings()
# name of the Redis search index to create
index_name = "products"
# assumes you have a redis stack server running on local host
redis_url = "redis://localhost:6379" # "redis://<your-redis-url>:6379
# %%
vectorstore = RedisVectorStore.from_texts(
texts=texts,
embedding=embedding,
metadatas=metadatas,
index_name=index_name,
redis_url=redis_url
)