{
"cells": [
{
"cell_type": "markdown",
"metadata": {
"id": "_kMfZv_2FGjO"
},
"source": [
"# ๐ฆ Notebook 1 โ Real-World Data Extraction & Synthetic Enrichment\n",
"### Project: E-Commerce Customer Intelligence โ Food & Grocery Products\n",
"**Business Question:** *How can an online food retailer reduce customer churn and optimize product positioning by analyzing review sentiment (qualitative) and rating/helpfulness patterns (quantitative)?*\n",
"\n",
"**Dataset:** Amazon Fine Food Reviews (Kaggle) โ 568,000+ real customer reviews\n"
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "XHzEidhsFGjP"
},
"source": [
"---\n",
"## ๐ฅ Step 0 โ How to get the Kaggle dataset\n",
"1. Go to: **https://www.kaggle.com/datasets/snap/amazon-fine-food-reviews**\n",
"2. Click **Download** (free Kaggle account required)\n",
"3. Extract the ZIP โ you get **`Reviews.csv`**\n",
"4. Upload `Reviews.csv` to Colab (folder icon โ upload)\n",
"5. Leave `CSV_FILE_PATH = \"Reviews.csv\"` as is\n",
"\n",
"> ๐ก No Kaggle account? The built-in food sample loads automatically as fallback."
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "v_7KefJ2FGjQ"
},
"source": [
"---\n",
"## โ๏ธ Step 1 โ Install & Import Libraries"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "fp_U4-syFGjQ",
"outputId": "24676d4a-9a89-416d-d213-a355fab148ed"
},
"outputs": [
{
"output_type": "execute_result",
"data": {
"text/plain": [
"True"
]
},
"metadata": {},
"execution_count": 2
}
],
"source": [
"!pip install pandas matplotlib seaborn textblob -q\n",
"import nltk\n",
"nltk.download('punkt', quiet=True)\n",
"nltk.download('averaged_perceptron_tagger', quiet=True)"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "SdBlUGWZFGjQ",
"outputId": "ac8f917f-3337-4b60-971e-61a26da480ef"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"โ All libraries imported successfully\n"
]
}
],
"source": [
"import pandas as pd\n",
"import numpy as np\n",
"import matplotlib.pyplot as plt\n",
"import seaborn as sns\n",
"import random\n",
"import os\n",
"from textblob import TextBlob\n",
"\n",
"pd.set_option('display.max_colwidth', 120)\n",
"plt.style.use('seaborn-v0_8-whitegrid')\n",
"random.seed(42)\n",
"np.random.seed(42)\n",
"\n",
"print('โ All libraries imported successfully')"
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "1xsy8-atFGjR"
},
"source": [
"---\n",
"## ๐ Step 2 โ Configuration"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "Fwdd5VqeFGjR",
"outputId": "6eae4756-fe27-4a6b-833e-6f191c7359b7"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"โ Config set โ will sample 500 reviews for analysis\n"
]
}
],
"source": [
"CSV_FILE_PATH = \"Reviews.csv\" # Kaggle Amazon Fine Food Reviews\n",
"N_SAMPLE = 500 # reviews to keep for analysis (adjust up to 2000 if you want more)\n",
"RANDOM_SEED = 42\n",
"\n",
"print(f'โ Config set โ will sample {N_SAMPLE} reviews for analysis')"
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "xl06KX7IFGjR"
},
"source": [
"---\n",
"## ๐ Step 3 โ Load Real-World Data"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 703
},
"id": "BtNjKFlgFGjR",
"outputId": "61efa873-1899-49ef-d972-f06794ee35e0"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"โ ๏ธ No CSV found โ using built-in food reviews sample...\n",
"โ Built-in food sample loaded: 500 rows\n"
]
},
{
"output_type": "execute_result",
"data": {
"text/plain": [
" ProductId product_name category Score \\\n",
"0 F001 Organic Green Tea Beverages 5 \n",
"1 F001 Organic Green Tea Beverages 1 \n",
"2 F002 Dark Chocolate Bar 70% Confectionery 5 \n",
"\n",
" Summary \\\n",
"0 Best tea I have ever had \n",
"1 Arrived stale and tasteless \n",
"2 Incredible quality chocolate \n",
"\n",
" Text \\\n",
"0 This organic green tea is absolutely wonderful. The flavour is delicate and fresh, nothing like the bitter supermark... \n",
"1 Extremely disappointed. The tea had no aroma whatsoever and tasted like hot water. The bags were clearly old stock. ... \n",
"2 This is hands down the best dark chocolate I have tasted outside of a specialist chocolatier. The bitterness is perf... \n",
"\n",
" HelpfulnessNumerator HelpfulnessDenominator \n",
"0 35 36 \n",
"1 26 30 \n",
"2 59 54 "
],
"text/html": [
"\n",
"
\n",
"
\n",
"\n",
"
\n",
" \n",
"
\n",
"
\n",
"
ProductId
\n",
"
product_name
\n",
"
category
\n",
"
Score
\n",
"
Summary
\n",
"
Text
\n",
"
HelpfulnessNumerator
\n",
"
HelpfulnessDenominator
\n",
"
\n",
" \n",
" \n",
"
\n",
"
0
\n",
"
F001
\n",
"
Organic Green Tea
\n",
"
Beverages
\n",
"
5
\n",
"
Best tea I have ever had
\n",
"
This organic green tea is absolutely wonderful. The flavour is delicate and fresh, nothing like the bitter supermark...
\n",
"
35
\n",
"
36
\n",
"
\n",
"
\n",
"
1
\n",
"
F001
\n",
"
Organic Green Tea
\n",
"
Beverages
\n",
"
1
\n",
"
Arrived stale and tasteless
\n",
"
Extremely disappointed. The tea had no aroma whatsoever and tasted like hot water. The bags were clearly old stock. ...
\n",
"
26
\n",
"
30
\n",
"
\n",
"
\n",
"
2
\n",
"
F002
\n",
"
Dark Chocolate Bar 70%
\n",
"
Confectionery
\n",
"
5
\n",
"
Incredible quality chocolate
\n",
"
This is hands down the best dark chocolate I have tasted outside of a specialist chocolatier. The bitterness is perf...
\n",
"
59
\n",
"
54
\n",
"
\n",
" \n",
"
\n",
"
\n",
"
\n",
"\n",
"
\n",
" \n",
"\n",
" \n",
"\n",
" \n",
"
\n",
"\n",
"\n",
"
\n",
"
\n"
],
"application/vnd.google.colaboratory.intrinsic+json": {
"type": "dataframe",
"variable_name": "df_raw",
"summary": "{\n \"name\": \"df_raw\",\n \"rows\": 500,\n \"fields\": [\n {\n \"column\": \"ProductId\",\n \"properties\": {\n \"dtype\": \"category\",\n \"num_unique_values\": 10,\n \"samples\": [\n \"F009\",\n \"F002\",\n \"F006\"\n ],\n \"semantic_type\": \"\",\n \"description\": \"\"\n }\n },\n {\n \"column\": \"product_name\",\n \"properties\": {\n \"dtype\": \"category\",\n \"num_unique_values\": 10,\n \"samples\": [\n \"Protein Granola\",\n \"Dark Chocolate Bar 70%\",\n \"Instant Ramen Variety Pack\"\n ],\n \"semantic_type\": \"\",\n \"description\": \"\"\n }\n },\n {\n \"column\": \"category\",\n \"properties\": {\n \"dtype\": \"category\",\n \"num_unique_values\": 8,\n \"samples\": [\n \"Confectionery\",\n \"Noodles\",\n \"Beverages\"\n ],\n \"semantic_type\": \"\",\n \"description\": \"\"\n }\n },\n {\n \"column\": \"Score\",\n \"properties\": {\n \"dtype\": \"number\",\n \"std\": 1,\n \"min\": 1,\n \"max\": 5,\n \"num_unique_values\": 5,\n \"samples\": [\n 1,\n 4,\n 2\n ],\n \"semantic_type\": \"\",\n \"description\": \"\"\n }\n },\n {\n \"column\": \"Summary\",\n \"properties\": {\n \"dtype\": \"category\",\n \"num_unique_values\": 20,\n \"samples\": [\n \"Best tea I have ever had\",\n \"Artificial sweetener aftertaste ruins it\",\n \"Oil separation is extreme and annoying\"\n ],\n \"semantic_type\": \"\",\n \"description\": \"\"\n }\n },\n {\n \"column\": \"Text\",\n \"properties\": {\n \"dtype\": \"category\",\n \"num_unique_values\": 20,\n \"samples\": [\n \"This organic green tea is absolutely wonderful. The flavour is delicate and fresh, nothing like the bitter supermarket brands. I have been drinking it every morning for 3 months and will never switch.\",\n \"The macros look great on paper but the stevia aftertaste is so strong it makes the whole bowl unpleasant. I pushed through two bags hoping to adjust but never did. The texture is good but that aftertaste is a dealbreaker.\",\n \"The product itself is fine but the oil separation is the worst I have experienced in any natural nut butter. You need to stir for several minutes before every use and it still does not mix properly. Very frustrating.\"\n ],\n \"semantic_type\": \"\",\n \"description\": \"\"\n }\n },\n {\n \"column\": \"HelpfulnessNumerator\",\n \"properties\": {\n \"dtype\": \"number\",\n \"std\": 18,\n \"min\": 4,\n \"max\": 78,\n \"num_unique_values\": 74,\n \"samples\": [\n 43,\n 63,\n 33\n ],\n \"semantic_type\": \"\",\n \"description\": \"\"\n }\n },\n {\n \"column\": \"HelpfulnessDenominator\",\n \"properties\": {\n \"dtype\": \"number\",\n \"std\": 18,\n \"min\": 12,\n \"max\": 73,\n \"num_unique_values\": 18,\n \"samples\": [\n 36,\n 30,\n 65\n ],\n \"semantic_type\": \"\",\n \"description\": \"\"\n }\n }\n ]\n}"
}
},
"metadata": {},
"execution_count": 5
}
],
"source": [
"def load_fallback_sample():\n",
" \"\"\"Built-in Food & Grocery sample โ loads if no CSV found.\"\"\"\n",
" print('โ ๏ธ No CSV found โ using built-in food reviews sample...')\n",
" records = [\n",
" {'ProductId':'F001','product_name':'Organic Green Tea','category':'Beverages','Score':5,\n",
" 'Summary':'Best tea I have ever had',\n",
" 'Text':'This organic green tea is absolutely wonderful. The flavour is delicate and fresh, nothing like the bitter supermarket brands. I have been drinking it every morning for 3 months and will never switch.','HelpfulnessNumerator':34,'HelpfulnessDenominator':36},\n",
" {'ProductId':'F001','product_name':'Organic Green Tea','category':'Beverages','Score':1,\n",
" 'Summary':'Arrived stale and tasteless',\n",
" 'Text':'Extremely disappointed. The tea had no aroma whatsoever and tasted like hot water. The bags were clearly old stock. I have tried to contact the seller with no response. Do not buy.','HelpfulnessNumerator':28,'HelpfulnessDenominator':30},\n",
" {'ProductId':'F002','product_name':'Dark Chocolate Bar 70%','category':'Confectionery','Score':5,\n",
" 'Summary':'Incredible quality chocolate',\n",
" 'Text':'This is hands down the best dark chocolate I have tasted outside of a specialist chocolatier. The bitterness is perfectly balanced with a hint of fruit. Melts beautifully. I order 6 bars at a time now.','HelpfulnessNumerator':52,'HelpfulnessDenominator':54},\n",
" {'ProductId':'F002','product_name':'Dark Chocolate Bar 70%','category':'Confectionery','Score':2,\n",
" 'Summary':'Way too bitter, packaging damaged',\n",
" 'Text':'The chocolate arrived with the wrapper partially open and one bar was broken into pieces. Even aside from that, 70% is too bitter for my taste. The description should be clearer about the intensity.','HelpfulnessNumerator':15,'HelpfulnessDenominator':18},\n",
" {'ProductId':'F003','product_name':'Extra Virgin Olive Oil','category':'Oils & Condiments','Score':5,\n",
" 'Summary':'Authentic and fragrant',\n",
" 'Text':'Finally found an olive oil that actually tastes like olive oil should. Peppery finish, grassy aroma, golden colour. I use it exclusively for salad dressings now. The quality is obvious from the first pour.','HelpfulnessNumerator':41,'HelpfulnessDenominator':43},\n",
" {'ProductId':'F003','product_name':'Extra Virgin Olive Oil','category':'Oils & Condiments','Score':3,\n",
" 'Summary':'Decent but nothing special',\n",
" 'Text':'It is a reasonable olive oil for everyday cooking but I would not call it extra virgin by taste. The aroma is mild and the flavour is neutral. Good value for the price but not premium quality.','HelpfulnessNumerator':9,'HelpfulnessDenominator':12},\n",
" {'ProductId':'F004','product_name':'Sourdough Crackers','category':'Snacks','Score':4,\n",
" 'Summary':'Great with cheese, slightly salty',\n",
" 'Text':'These crackers are excellent with cheese and charcuterie. The sourdough flavour is authentic and the texture is perfectly crispy. Only minor complaint is they are a bit salty on their own. Would buy again.','HelpfulnessNumerator':22,'HelpfulnessDenominator':23},\n",
" {'ProductId':'F004','product_name':'Sourdough Crackers','category':'Snacks','Score':1,\n",
" 'Summary':'Half the box was broken crumbs',\n",
" 'Text':'Terrible packaging. More than half the crackers arrived as crumbs because there is no internal protection in the box. The flavour was fine but completely unusable. I expect better for the price charged.','HelpfulnessNumerator':38,'HelpfulnessDenominator':40},\n",
" {'ProductId':'F005','product_name':'Manuka Honey 250g','category':'Spreads','Score':5,\n",
" 'Summary':'Worth every penny for the health benefits',\n",
" 'Text':'I have been taking a teaspoon of this every morning for my immune system and have noticed a real difference. The flavour is rich and distinctive. Authentic UMF rating, good traceability. Highly recommended.','HelpfulnessNumerator':63,'HelpfulnessDenominator':65},\n",
" {'ProductId':'F005','product_name':'Manuka Honey 250g','category':'Spreads','Score':2,\n",
" 'Summary':'Not convinced it is genuine Manuka',\n",
" 'Text':'For the price I expected more. The taste is sweeter than authentic Manuka should be and the UMF certification seems dubious. I have bought certified Manuka before and this does not compare. Very suspicious.','HelpfulnessNumerator':44,'HelpfulnessDenominator':48},\n",
" {'ProductId':'F006','product_name':'Instant Ramen Variety Pack','category':'Noodles','Score':4,\n",
" 'Summary':'Great variety, solid flavour all round',\n",
" 'Text':'Good selection of flavours in the pack. The spicy chicken is our household favourite. Quick to prepare and genuinely tasty for an instant product. The portion size is generous. Will subscribe for monthly delivery.','HelpfulnessNumerator':17,'HelpfulnessDenominator':18},\n",
" {'ProductId':'F006','product_name':'Instant Ramen Variety Pack','category':'Noodles','Score':2,\n",
" 'Summary':'Far too much sodium, bland broth',\n",
" 'Text':'The sodium content in these is absolutely alarming at over 1700mg per serving. The broth tastes more like salt water than anything else. I tried three flavours and they were all disappointing. Not worth it.','HelpfulnessNumerator':29,'HelpfulnessDenominator':31},\n",
" {'ProductId':'F007','product_name':'Cold Brew Coffee Concentrate','category':'Beverages','Score':5,\n",
" 'Summary':'Smooth, rich and incredibly convenient',\n",
" 'Text':'This cold brew concentrate has completely replaced my morning coffee shop habit. I just dilute 1:3 with milk and it is better than anything I can buy locally. Smooth, zero bitterness, great crema. Obsessed.','HelpfulnessNumerator':71,'HelpfulnessDenominator':73},\n",
" {'ProductId':'F007','product_name':'Cold Brew Coffee Concentrate','category':'Beverages','Score':1,\n",
" 'Summary':'Leaked all over the box, appalling',\n",
" 'Text':'The bottle seal failed in transit and the entire contents leaked destroying everything else in the delivery. There was no protective packaging around the bottle at all. This is basic logistics. Absolutely unacceptable.','HelpfulnessNumerator':55,'HelpfulnessDenominator':57},\n",
" {'ProductId':'F008','product_name':'Almond Butter Smooth','category':'Spreads','Score':4,\n",
" 'Summary':'Clean ingredients, tastes great',\n",
" 'Text':'Just almonds and a pinch of salt. No palm oil, no added sugar. The flavour is nutty and rich and it spreads well even straight from the fridge. Slightly expensive but the quality justifies it. Solid product.','HelpfulnessNumerator':26,'HelpfulnessDenominator':27},\n",
" {'ProductId':'F008','product_name':'Almond Butter Smooth','category':'Spreads','Score':3,\n",
" 'Summary':'Oil separation is extreme and annoying',\n",
" 'Text':'The product itself is fine but the oil separation is the worst I have experienced in any natural nut butter. You need to stir for several minutes before every use and it still does not mix properly. Very frustrating.','HelpfulnessNumerator':12,'HelpfulnessDenominator':14},\n",
" {'ProductId':'F009','product_name':'Protein Granola','category':'Breakfast','Score':5,\n",
" 'Summary':'High protein and actually delicious',\n",
" 'Text':'I have tried many protein granolas and they are usually chalky or overly sweet. This one is genuinely good. Crunchy clusters, real nuts, 20g protein per serving. Goes perfectly with Greek yoghurt. Reordering today.','HelpfulnessNumerator':33,'HelpfulnessDenominator':35},\n",
" {'ProductId':'F009','product_name':'Protein Granola','category':'Breakfast','Score':2,\n",
" 'Summary':'Artificial sweetener aftertaste ruins it',\n",
" 'Text':'The macros look great on paper but the stevia aftertaste is so strong it makes the whole bowl unpleasant. I pushed through two bags hoping to adjust but never did. The texture is good but that aftertaste is a dealbreaker.','HelpfulnessNumerator':21,'HelpfulnessDenominator':23},\n",
" {'ProductId':'F010','product_name':'Pasta Sauce Arrabbiata','category':'Sauces','Score':5,\n",
" 'Summary':'Authentic Italian flavour',\n",
" 'Text':'This sauce tastes like something from a Roman trattoria. The heat level is perfect, the tomatoes are clearly good quality and the whole thing is fragrant and fresh tasting. No unnecessary additives. Simply excellent.','HelpfulnessNumerator':48,'HelpfulnessDenominator':50},\n",
" {'ProductId':'F010','product_name':'Pasta Sauce Arrabbiata','category':'Sauces','Score':1,\n",
" 'Summary':'Jar arrived broken, glass in the sauce',\n",
" 'Text':'The jar cracked during delivery and when I opened it I could see glass fragments near the top. Clearly the courier handling was rough but there was also no protective padding in the box. Dangerous and unacceptable.','HelpfulnessNumerator':67,'HelpfulnessDenominator':68},\n",
" ]\n",
" extended = (records * 25)[:500]\n",
" df = pd.DataFrame(extended)\n",
" df['HelpfulnessNumerator'] = df['HelpfulnessNumerator'].apply(lambda x: max(0, x + np.random.randint(-5,8)))\n",
" print(f'โ Built-in food sample loaded: {len(df)} rows')\n",
" return df\n",
"\n",
"# Load\n",
"if os.path.exists(CSV_FILE_PATH):\n",
" df_raw = pd.read_csv(CSV_FILE_PATH, on_bad_lines='skip', engine='python', nrows=10000)\n",
" print(f'โ Kaggle CSV loaded: {df_raw.shape}')\n",
" print(f' Columns: {list(df_raw.columns)}')\n",
"else:\n",
" df_raw = load_fallback_sample()\n",
"\n",
"df_raw.head(3)"
]
},
{
"cell_type": "code",
"source": [
"df_raw.to_csv(\"food_dataset.csv\", index=False)"
],
"metadata": {
"id": "4SCK_Wqew-pJ"
},
"execution_count": null,
"outputs": []
},
{
"cell_type": "markdown",
"metadata": {
"id": "5PCVcj5JFGjS"
},
"source": [
"---\n",
"## ๐งน Step 4 โ Data Cleaning & Standardisation"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "kFwPNZK5FGjS",
"outputId": "42912beb-caea-45c9-cf6f-1ac722c301f0"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"โ After cleaning: 500 rows ร 8 columns\n",
"\n",
"Rating distribution:\n",
"rating\n",
"1 100\n",
"2 100\n",
"3 50\n",
"4 75\n",
"5 175\n"
]
}
],
"source": [
"def clean_dataframe(df):\n",
" # Rename to standard schema (handles Amazon Fine Food columns)\n",
" col_map = {\n",
" 'ProductId' : 'product_id',\n",
" 'Score' : 'rating',\n",
" 'Summary' : 'review_title',\n",
" 'Text' : 'review_text',\n",
" 'HelpfulnessNumerator' : 'helpful_votes',\n",
" 'HelpfulnessDenominator': 'total_votes',\n",
" 'UserId' : 'user_id',\n",
" 'Time' : 'timestamp',\n",
" 'ProfileName' : 'reviewer_name',\n",
" }\n",
" df = df.rename(columns={k:v for k,v in col_map.items() if k in df.columns})\n",
"\n",
" essential = ['product_id','rating','review_title','review_text']\n",
" optional = ['product_name','category','helpful_votes','total_votes',\n",
" 'user_id','timestamp','reviewer_name']\n",
" keep = [c for c in essential + optional if c in df.columns]\n",
" df = df[keep].copy()\n",
"\n",
" # Drop missing critical fields\n",
" df = df.dropna(subset=['review_text','rating'])\n",
" df['rating'] = pd.to_numeric(df['rating'], errors='coerce')\n",
" df = df[df['rating'].between(1,5)].copy()\n",
" df['rating'] = df['rating'].astype(int)\n",
"\n",
" # Remove very short reviews\n",
" df = df[df['review_text'].astype(str).str.len() >= 40].copy()\n",
"\n",
" # Clean text\n",
" df['review_text'] = df['review_text'].astype(str).str.replace(' ', ' ').str.replace(' ', ' ').str.strip()\n",
" df['review_title'] = df['review_title'].fillna('No title').astype(str).str.strip()\n",
"\n",
" # Helpful votes\n",
" if 'helpful_votes' in df.columns:\n",
" df['helpful_votes'] = pd.to_numeric(df['helpful_votes'], errors='coerce').fillna(0).astype(int)\n",
"\n",
" return df.reset_index(drop=True)\n",
"\n",
"df_clean = clean_dataframe(df_raw)\n",
"\n",
"print(f'โ After cleaning: {df_clean.shape[0]:,} rows ร {df_clean.shape[1]} columns')\n",
"print(f'\\nRating distribution:')\n",
"print(df_clean['rating'].value_counts().sort_index().to_string())"
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "ABdG_Rs8FGjS"
},
"source": [
"---\n",
"## ๐ Step 5 โ Sample & Preview Raw Data"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 451
},
"id": "gkrV0ZgZFGjS",
"outputId": "06d5b756-84cb-45b4-a41c-74fdfa88c091"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"๐ Working sample: 425 reviews\n",
" Rating distribution: {1: 100, 2: 100, 3: 50, 4: 75, 5: 100}\n",
" Unique products : 10\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"/tmp/ipykernel_2503/3507263612.py:35: UserWarning: Glyph 11088 (\\N{WHITE MEDIUM STAR}) missing from font(s) Liberation Sans.\n",
" plt.tight_layout()\n",
"/tmp/ipykernel_2503/3507263612.py:36: UserWarning: Glyph 11088 (\\N{WHITE MEDIUM STAR}) missing from font(s) Liberation Sans.\n",
" plt.savefig('01_raw_data_overview.png', dpi=150, bbox_inches='tight')\n",
"/usr/local/lib/python3.12/dist-packages/IPython/core/pylabtools.py:151: UserWarning: Glyph 11088 (\\N{WHITE MEDIUM STAR}) missing from font(s) Liberation Sans.\n",
" fig.canvas.print_figure(bytes_io, **kw)\n"
]
},
{
"output_type": "display_data",
"data": {
"text/plain": [
"
"
],
"image/png": "iVBORw0KGgoAAAANSUhEUgAABKAAAAHvCAYAAABjb6eiAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAsg5JREFUeJzs3Xl8DOcfB/DPZnOLJBIEQagjjgRBRAkh7psoRVFHiyrqamlRqoe6ilL3VVcR932fIe4gjjoSR0TkPuTc8/dHfjvNyiEbu5kcn/fr1Vft7OzMZ3YmuzPffZ5nJGq1Wg0iIiIiIiIiIiIDMRI7ABERERERERERFW0sQBERERERERERkUGxAEVERERERERERAbFAhQRERERERERERkUC1BERERERERERGRQLEAREREREREREZFBsQBFREREREREREQGxQIUEREREREREREZFAtQRERERERERERkUMZiByAiouJj0KBBuHbtWpbPmZmZoUKFCvD09MSXX34JBweHfE6XtT179uD777/XmmZkZISSJUvCyckJHh4e6NOnD5ycnD5oPa9fv8bu3bvRpEkTeHh4fNCyshIXF4d//vkH58+fx7Nnz5CYmAgrKyt89NFHaN26Nfr16wdra2u9r9eQrl69isGDBwMA5syZAx8fH5ET5b9ff/0VmzZtAgBIJBKcPHkSlSpVEjlVwZbxuMlJr1698PvvvxeY4yynz8+MTp8+jYoVK+ZDoqxNnToVe/fuzVUWb29vhIaGZvmchYUFKlWqBG9vbwwbNgw2NjYGyZuRs7MzgP/2PRER6RcLUEREJIpGjRpBKpUCAFQqFcLCwvDs2TM8e/YMBw8exLZt21CtWjWRU2pzcnKCg4MDlEolIiIicPfuXdy9excbN27EhAkTMHz48Dwve+/evVi2bBnGjBmj9wLUlStXMH78eMTGxgIAHB0dUbVqVURERODWrVu4desWNm7ciD///BONGzfW67oNydraGk2aNAEAlC5dWuQ0+U8ul+PgwYPCY7VajX379mHs2LEipipcypUrh8qVK2f53EcffQSgYB5nGT8/32VmZpbPaT6csbExGjZsKDxWKpV4+fIlHj9+jMePH+PgwYPw9fWFvb29QXNo9rNm3xMRkX6xAEVERKJYs2YNSpQooTVty5Yt+PnnnxEXF4c///wTS5YsESld1gYPHoyB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06dISkqCm5sbZs+ejeXLl2uN+9W8eXPs3r0b3bt3h42NDR4/fgylUomPP/4YixYtylToXrJkiVAUSUlJgbm5OVauXInGjRvrbRsmT54sDOq+bNkyoXugl5cXtm3bBm9vb5iZmeH+/ftQqVTo0KED/vnnH6ErtIaNjY3wgwWQ3oUwt92vdfls+5Dvn0WLFuH7779HvXr1EBkZibt37yIpKQmNGzfGTz/9JAxMTkRUmEnUbMtJREREREREREQGxBZQRERERERERERkUCxAERERERERERGRQbEARUREREREREREBsUCFBERERERERERGRQLUEREREREREREZFAsQBERERERERERkUGxAEVERERERERERAbFAhQRERERERERERkUC1BERERERERERGRQLEAREREREREREZFBsQBFREREREREREQGxQIUEREREREREREZFAtQRERERERERERkUCxAERERERERERGRQbEARUREREREREREBsUCFBERERERERERGRQLUEREREREREREZFAsQBERERERERERkUGxAEVERERERERERAbFAhQRERERERERERkUC1BERERERERERGRQLEAREREREREREZFBsQBFREREREREREQGxQIUUTHg7e0NZ2fnTP+5ubmhX79+2Ldvn17W8+rVK2HZr1690ssyc2PQoEFa21WnTh00b94cI0eOxNGjR7Odf+nSpQbLdPXqVSFPfq4XgLDeq1evGnQ971Kr1ejXr1+mbTx8+DA+//xzeHp6om7dumjUqBH69OmDf/75J1/z5VZe9pPmNQsXLjRgMiIiyquszoVcXFzQpk0bjBkzBg8ePBAtm5jnDBklJydj3bp18PHxgYeHB+rWrYuPP/4Yw4cPx5UrV/ItB5D1e1JYTZgwAc7Ozpg6dSoAQCaT4dtvv4WbmxtcXV2xfv16kRNmLTQ0FHPmzEHHjh3h5uYGFxcXtGrVCt9++y1CQkLyPc/UqVOzvJ5xdXVFp06dsHTpUqSlpellXZrPiz179uhleRnJZDJ06NABzs7O2L59u96XX9AZix2AiPJPvXr10KBBAwDpxYLHjx/j6tWrCAgIQFRUFL744gudljds2DA8f/4cZ86cAQBYWVlh8ODBwr/z20cffQRPT08olUoEBwfjwoULOHfuHA4dOoTFixfDxMQEANChQwfUqlUL9evX12n5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0siRI7V161a98847+v3vf3/Kc23cuFHdu3fXn//8Z23YsEGTJk3S2LFj1b17d913331qaGjQ3/72Nx06dEjTp0/38zsFAAAAgNNjBhQA+NDIkSOVkpIiy7KUlZWldevWacCAAbIsS/3791dycrI+/fTTszqX3W7X1KlT5XQ61b9/fyUlJamiokJNTU165513NHnyZCUmJqpDhw668sorffzOAAAAAODsMQMKAHyoXbt2zX+3LEuvvvqqXn/9de3bt08ej0f19fWqr68/63PZbN/83iAqKkq1tbWqrKxUQ0ODMjMzm/cVFhZ6700AAAAAwDmigAIAH7Lb7c1/X7ZsmRYvXqxnn31Wffr0kd1u16BBg876XCeWTyf698NMHQ7Hdx4LAAAAACbwLxQA8JPS0lIVFxerX79+stvt2r9/v/bt23fO501MTJTdbtfnn3/e4loAAAAAECgooADATzIzM7Vt2zYdPnxYe/bs0dy5c9WuXTt9+eWXkiSXy6X9+/ersrLyrG/Lk47PsiouLtaSJUtUXV2t7du3a9myZb56GwAAAADQahRQAOAnV199tXJycjRo0CBNmTJF1113na677jotWbJEr7zyioYPHy6Px6PBgwdr06ZNrTr3I488oqqqKl1wwQW69957NXXqVEncigcAAAAgMFiefy8eAgAIavX19XI6nZKkdevW6aabbtInn3zSvA0AAAAATOFX4wAQAmbPnq1bbrlFVVVVqq6u1pIlSzRgwADKJwAAAAABgQIKAELAzJkzlZCQoOHDh2v48OGy2+165JFHTMcCAAAAAEncggcAAAAAAAAfYwYUAAAAAAAAfIoCCgAAAAAAAD5FAQUAAAAAAACfooACAAAAAACAT1FAAQAAAAAAwKcooAAAAAAAAOBTFFAAAAAAAADwKQooAAAAAAAA+BQFFAAAAAAAAHzq/wOM8l90Brqi5AAAAABJRU5ErkJggg==\n"
},
"metadata": {}
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"๐ Saved: 01_raw_data_overview.png\n"
]
}
],
"source": [
"# Stratified sample โ equal reviews per star rating for balanced analysis\n",
"per_rating = N_SAMPLE // 5\n",
"df_sample = pd.concat([\n",
" df_clean[df_clean['rating']==s].sample(\n",
" n=min(per_rating, (df_clean['rating']==s).sum()),\n",
" random_state=RANDOM_SEED\n",
" )\n",
" for s in [1,2,3,4,5]\n",
"]).sample(frac=1, random_state=RANDOM_SEED).reset_index(drop=True)\n",
"\n",
"print(f'๐ Working sample: {len(df_sample)} reviews')\n",
"print(f' Rating distribution: {df_sample[\"rating\"].value_counts().sort_index().to_dict()}')\n",
"print(f' Unique products : {df_sample[\"product_id\"].nunique()}')\n",
"\n",
"fig, axes = plt.subplots(1, 2, figsize=(13, 5))\n",
"fig.suptitle('Raw Data Overview โ Amazon Fine Food Reviews', fontsize=14, fontweight='bold')\n",
"\n",
"df_sample['rating'].value_counts().sort_index().plot(\n",
" kind='bar', ax=axes[0],\n",
" color=['#e74c3c','#e67e22','#f1c40f','#2ecc71','#27ae60'], edgecolor='white'\n",
")\n",
"axes[0].set_title('Rating Distribution (Sample)', fontweight='bold')\n",
"axes[0].set_xticklabels(['1โญ','2โญ','3โญ','4โญ','5โญ'], rotation=0)\n",
"axes[0].set_ylabel('Number of Reviews')\n",
"for p in axes[0].patches:\n",
" axes[0].annotate(str(int(p.get_height())),\n",
" (p.get_x()+p.get_width()/2, p.get_height()),\n",
" ha='center', va='bottom', fontsize=10)\n",
"\n",
"rule_sent = df_sample['rating'].map({1:'Negative',2:'Negative',3:'Neutral',4:'Positive',5:'Positive'}).value_counts()\n",
"axes[1].pie(rule_sent, labels=rule_sent.index, autopct='%1.1f%%', startangle=90,\n",
" colors=[{'Positive':'#27ae60','Neutral':'#f39c12','Negative':'#e74c3c'}.get(s,'grey') for s in rule_sent.index])\n",
"axes[1].set_title('Baseline Sentiment (from Star Rating)', fontweight='bold')\n",
"\n",
"plt.tight_layout()\n",
"plt.savefig('01_raw_data_overview.png', dpi=150, bbox_inches='tight')\n",
"plt.show()\n",
"print('๐ Saved: 01_raw_data_overview.png')"
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "_36yXm5AFGjS"
},
"source": [
"---\n",
"## ๐ค Step 6 โ TextBlob Sentiment Enrichment\n",
"No API needed โ runs locally and instantly."
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "do-M5kLNFGjS",
"outputId": "463075b2-d481-4bc7-b087-a22f88033dfa"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"๐ Computing TextBlob sentiment...\n",
"โ Done โ 425 reviews labelled\n",
"\n",
"Sentiment distribution:\n",
"sentiment_label\n",
"Positive 207\n",
"Neutral 168\n",
"Negative 50\n"
]
}
],
"source": [
"def get_sentiment(text):\n",
" score = round(TextBlob(str(text)).sentiment.polarity, 3)\n",
" if score > 0.1: label = 'Positive'\n",
" elif score < -0.1: label = 'Negative'\n",
" else: label = 'Neutral'\n",
" return label, score\n",
"\n",
"print('๐ Computing TextBlob sentiment...')\n",
"results = df_sample['review_text'].apply(get_sentiment)\n",
"df_sample['sentiment_label'] = results.apply(lambda x: x[0])\n",
"df_sample['sentiment_score'] = results.apply(lambda x: x[1])\n",
"\n",
"print(f'โ Done โ {len(df_sample)} reviews labelled')\n",
"print(f'\\nSentiment distribution:')\n",
"print(df_sample['sentiment_label'].value_counts().to_string())"
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "lcud7PwIFGjS"
},
"source": [
"---\n",
"## ๐งฌ Step 7 โ Synthetic Data Generation\n",
"Pre-written food review pools (same approach as class notebook).\n",
"Generated with LLM assistance and hardcoded โ **no API calls**."
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "m9KLWGrgFGjS",
"outputId": "ea5f9654-ff90-47aa-d73f-17401d289969"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"โ Food synthetic review pools ready\n",
" Positive: 20 reviews\n",
" Neutral: 20 reviews\n",
" Negative: 20 reviews\n"
]
}
],
"source": [
"# โโ FOOD-SPECIFIC SYNTHETIC REVIEW POOLS โโโโโโโโโโโโโโโโโโโโโโโโโ\n",
"# Created by prompting an LLM:\n",
"# \"Write 20 realistic Amazon food product reviews that are [positive/neutral/negative].\n",
"# Vary the products: snacks, beverages, condiments, health foods.\"\n",
"\n",
"synthetic_reviews_by_sentiment = {\n",
"\n",
" 'Positive': [\n",
" \"Absolutely the best version of this product I have ever tried. The flavour is authentic and the quality is clearly a step above the supermarket equivalent.\",\n",
" \"I ordered this on a whim and it has become a household staple. We go through a pack every week. The taste is consistent and the price is fair for the quality.\",\n",
" \"Exceptional product. Fresh, well packaged and exactly as described. The flavour profile is complex and satisfying. Will definitely be reordering regularly.\",\n",
" \"This exceeded my expectations completely. I was sceptical but the reviews were right. Outstanding flavour and the ingredients list is clean and simple.\",\n",
" \"Best purchase I have made on this platform. The product arrived quickly, was well protected and tasted incredible straight out of the packaging.\",\n",
" \"I have tried many similar products and this is head and shoulders above the competition. Rich, full flavoured and zero artificial aftertaste.\",\n",
" \"Five stars without hesitation. This is the kind of quality you expect from a specialist supplier. The freshness is obvious and the taste is superb.\",\n",
" \"My whole family loves this. We have been buying it for six months and the quality has been absolutely consistent every single time. Highly recommend.\",\n",
" \"Genuinely delicious. I bought this as a gift and the recipient immediately asked where to get more. That says everything about the quality.\",\n",
" \"Perfect product. The packaging keeps everything fresh, the flavour is exactly right and the portion size is generous. Great value for money.\",\n",
" \"I am so glad I found this. It has transformed the way I cook and the flavour it adds is remarkable. Worth every penny and I will never go back.\",\n",
" \"Outstanding quality from start to finish. The aroma when you open the packaging is wonderful and the taste lives up to it completely.\",\n",
" \"This is now my go-to product in this category. Consistent quality, brilliant taste and it keeps well. Cannot recommend it highly enough.\",\n",
" \"Honestly surprised by how good this is. The description does not do it justice. Rich, satisfying and made with ingredients you can actually read.\",\n",
" \"Subscribed after the first order. The value is excellent for the quality and my morning routine has genuinely improved since I started using it.\",\n",
" \"Fantastic product that delivers on every single claim on the label. Fresh, flavourful and made the right way. A cut above everything else I have tried.\",\n",
" \"The whole household is obsessed. We have already reordered three times. Great flavour, clean label and arrives perfectly packaged every time.\",\n",
" \"Exactly what I was looking for. High quality ingredients, honest flavour and no unnecessary additives. This is how food should be made.\",\n",
" \"Brilliant find. I bought it based on reviews and the reviews were absolutely right. Delicious, fresh and great for the price. Will reorder always.\",\n",
" \"A product that genuinely lives up to its reputation. The quality is premium, the taste is exceptional and the packaging is thoughtful and secure.\",\n",
" ],\n",
"\n",
" 'Neutral': [\n",
" \"Decent product that does what it says. Nothing groundbreaking but a reliable choice. I would buy it again if I could not find anything better locally.\",\n",
" \"It is fine. The flavour is acceptable and the quality is what you would expect at this price point. Not remarkable but not disappointing either.\",\n",
" \"Average experience overall. The product is edible and the packaging is adequate. I expected more based on the description but it is not bad.\",\n",
" \"Mixed feelings. Some of the product was great and some was underwhelming. Inconsistent quality across the batch which was a bit frustrating.\",\n",
" \"It does the job. Not the most exciting product in the category but reliable and practical. A reasonable everyday option at a fair price.\",\n",
" \"Three stars because it is neither impressive nor terrible. Solid middle ground product. Functional and consistent if not particularly memorable.\",\n",
" \"I have bought better and I have bought worse. This sits comfortably in the middle. Worth trying but manage your expectations accordingly.\",\n",
" \"The flavour is pleasant enough without being outstanding. Would work well as part of a recipe but perhaps not as a standalone snack.\",\n",
" \"Not sure if I would reorder. The quality is acceptable but there is nothing that distinguishes this from a cheaper supermarket alternative.\",\n",
" \"Reasonable product for the price. Arrived in good condition and tasted fine. Just nothing special that would make me prioritise it over other options.\",\n",
" \"Okay but not memorable. The ingredients are fine, the texture is acceptable, the flavour is inoffensive. A three-star product in every sense.\",\n",
" \"Does what it says on the label, no more and no less. I appreciate the clean ingredients but the overall experience was a bit flat.\",\n",
" \"Perfectly serviceable. I used it up without complaint but also without enthusiasm. There are probably better options in this category if you look around.\",\n",
" \"Average quality, average taste, average experience. Not a bad product but certainly not a great one. Probably will not repurchase at this price.\",\n",
" \"It is fine for what it is. The convenience factor is decent and the flavour is acceptable. Just do not expect anything extraordinary.\",\n",
" \"A middle-of-the-road purchase. Not the worst thing I have bought and not the best. Gets the job done without exciting or disappointing.\",\n",
" \"The product is what it is. Good enough for regular use but I would not recommend it to anyone looking for something exceptional.\",\n",
" \"Three stars feels right. Competent product, no major issues, but also no reason to choose it over competitors unless the price is right.\",\n",
" \"Perfectly adequate. There is nothing wrong with it but there is also nothing that makes it stand out. A background product rather than a star.\",\n",
" \"It gets the job done. Taste is neutral, texture is acceptable, packaging is functional. Nothing to rave about but nothing to complain about either.\",\n",
" ],\n",
"\n",
" 'Negative': [\n",
" \"Extremely disappointed. The product looked nothing like the photos and the taste was completely off. This does not match the description at all.\",\n",
" \"Arrived in terrible condition. The packaging was crushed and the product inside was damaged beyond use. No protective padding whatsoever.\",\n",
" \"Worst food purchase I have made online. The smell when I opened it was immediately wrong. Clearly old stock being sold as fresh. Do not buy.\",\n",
" \"The product is fine but the portion size is a complete joke for the price. I cannot believe the amount you actually get. Total rip off.\",\n",
" \"Flavour is artificial and overwhelming. Nothing like the natural product it claims to be. The ingredient list does not match the front of the pack.\",\n",
" \"I received the wrong item and when I contacted support the response was dismissive and unhelpful. Still waiting for a resolution two weeks later.\",\n",
" \"Mouldy on arrival. Clearly stored badly before dispatch. The best before date had not passed but the product was inedible. Shocking quality control.\",\n",
" \"The sodium level in this product is dangerous. Over 2000mg per serving is not something that should be on shelves without a clear health warning.\",\n",
" \"Absolutely terrible. I followed the preparation instructions exactly and the result was inedible. I cannot understand how this product has positive reviews.\",\n",
" \"Leaking packaging meant the product was ruined and contaminated other items in the delivery. Completely unacceptable and a waste of money.\",\n",
" \"Do not believe the health claims on this packaging. They are wildly misleading and the actual nutritional content tells a very different story.\",\n",
" \"The quality has clearly dropped since previous orders. Same product but completely different taste. Either the recipe has changed or the ingredients.\",\n",
" \"I have been sick after eating this product. I cannot prove it was the cause but the timing and symptoms were very suspicious. Removing from my diet.\",\n",
" \"Ordered twice hoping the first bad experience was a fluke. Both times the same problem. Clearly a systemic issue with this product. Giving up.\",\n",
" \"The product contains allergens not listed on the website description. This is a serious safety issue that needs to be addressed immediately.\",\n",
" \"Stale, tasteless and overpriced. I have bought the supermarket version for a third of the price and it is genuinely better. Complete waste of money.\",\n",
" \"Customer service was appalling when I reported the issue. Dismissive, slow and ultimately unhelpful. Will not be using this seller again.\",\n",
" \"The texture is completely wrong for this type of product. It was gummy and unpleasant where it should have been light and crisp. Inedible.\",\n",
" \"One star because zero is not an option. Every aspect of this purchase was a disappointment from the misleading photos to the awful flavour.\",\n",
" \"Returned immediately. The product was clearly not as advertised and the quality was so poor that I questioned whether it was genuine at all.\",\n",
" ]\n",
"}\n",
"\n",
"print('โ Food synthetic review pools ready')\n",
"for s, r in synthetic_reviews_by_sentiment.items():\n",
" print(f' {s}: {len(r)} reviews')"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 1000
},
"id": "PpvNBJpZFGjT",
"outputId": "3f8f6b0e-876c-4483-9a10-2271c28b91af"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"โ Generated 60 synthetic food reviews across 6 products\n",
"\n",
"Synthetic sentiment distribution:\n",
"sentiment_label\n",
"Positive 30\n",
"Negative 20\n",
"Neutral 10\n"
]
},
{
"output_type": "execute_result",
"data": {
"text/plain": [
" product_name category rating sentiment_label \\\n",
"0 Organic Matcha Powder Beverages 5 Positive \n",
"1 Organic Matcha Powder Beverages 5 Positive \n",
"2 Organic Matcha Powder Beverages 5 Positive \n",
"3 Organic Matcha Powder Beverages 5 Positive \n",
"4 Organic Matcha Powder Beverages 5 Positive \n",
"\n",
" review_text \n",
"0 This exceeded my expectations completely. I was sceptical but the reviews were right. Outstanding flavour and the in... \n",
"1 Absolutely the best version of this product I have ever tried. The flavour is authentic and the quality is clearly a... \n",
"2 Genuinely delicious. I bought this as a gift and the recipient immediately asked where to get more. That says everyt... \n",
"3 My whole family loves this. We have been buying it for six months and the quality has been absolutely consistent eve... \n",
"4 The whole household is obsessed. We have already reordered three times. Great flavour, clean label and arrives perfe... "
],
"text/html": [
"\n",
"
\n",
"
\n",
"\n",
"
\n",
" \n",
"
\n",
"
\n",
"
product_name
\n",
"
category
\n",
"
rating
\n",
"
sentiment_label
\n",
"
review_text
\n",
"
\n",
" \n",
" \n",
"
\n",
"
0
\n",
"
Organic Matcha Powder
\n",
"
Beverages
\n",
"
5
\n",
"
Positive
\n",
"
This exceeded my expectations completely. I was sceptical but the reviews were right. Outstanding flavour and the in...
\n",
"
\n",
"
\n",
"
1
\n",
"
Organic Matcha Powder
\n",
"
Beverages
\n",
"
5
\n",
"
Positive
\n",
"
Absolutely the best version of this product I have ever tried. The flavour is authentic and the quality is clearly a...
\n",
"
\n",
"
\n",
"
2
\n",
"
Organic Matcha Powder
\n",
"
Beverages
\n",
"
5
\n",
"
Positive
\n",
"
Genuinely delicious. I bought this as a gift and the recipient immediately asked where to get more. That says everyt...
\n",
"
\n",
"
\n",
"
3
\n",
"
Organic Matcha Powder
\n",
"
Beverages
\n",
"
5
\n",
"
Positive
\n",
"
My whole family loves this. We have been buying it for six months and the quality has been absolutely consistent eve...
\n",
"
\n",
"
\n",
"
4
\n",
"
Organic Matcha Powder
\n",
"
Beverages
\n",
"
5
\n",
"
Positive
\n",
"
The whole household is obsessed. We have already reordered three times. Great flavour, clean label and arrives perfe...