| | |
| |
|
| | import numpy as np |
| | import joblib |
| | import pandas as pd |
| | from flask import Flask, request, jsonify |
| | import sys |
| | import custom_transformers |
| |
|
| | |
| | sys.modules['__main__'] = sys.modules[__name__] |
| | sys.modules['__main__'].ProductPrefixExtractor = custom_transformers.ProductPrefixExtractor |
| | sys.modules['__main__'].StoreAgeBinner = custom_transformers.StoreAgeBinner |
| | sys.modules['__main__'].store_age_transformer = custom_transformers.store_age_transformer |
| | sys.modules['__main__'].convert_year_to_age = custom_transformers.convert_year_to_age |
| |
|
| | |
| | sales_predictor_api = Flask("Retail Sales Prediction API") |
| |
|
| | |
| | model = joblib.load("SuperKart_sales_rf_tuned_prediction_model_p1_0.joblib") |
| |
|
| | |
| | @sales_predictor_api.get('/') |
| | def home(): |
| | """ |
| | This function handles GET requests to the root URL ('/') of the API. |
| | It returns a simple welcome message. |
| | """ |
| | return "Welcome to the Retail Sales Prediction API!" |
| |
|
| |
|
| | |
| | @sales_predictor_api.route('/v1/sales', methods=['POST']) |
| | def predict_sales(): |
| | """ |
| | Expects JSON with feature key-value pairs. |
| | Returns predicted sales value. |
| | """ |
| | data = request.get_json() |
| | try: |
| | |
| | features = { |
| | 'Store_Establishment_Year': data['Store_Establishment_Year'], |
| | 'Product_MRP': data['Product_MRP'], |
| | 'Product_Weight': data['Product_Weight'], |
| | 'Store_Id': data['Store_Id'], |
| | 'Product_Type': data['Product_Type'], |
| | 'Product_Sugar_Content': data['Product_Sugar_Content'], |
| | 'Store_Location_City_Type': data['Store_Location_City_Type'], |
| | 'Store_Size': data['Store_Size'], |
| | 'Product_Allocated_Area': data['Product_Allocated_Area'], |
| | 'Product_Id': data['Product_Id'], |
| | 'Store_Type': data['Store_Type'], |
| | |
| | } |
| | |
| | input_df = pd.DataFrame([features]) |
| | |
| | predicted_sales = model.predict(input_df)[0] |
| | |
| | predicted_sales = round(float(predicted_sales), 2) |
| | |
| | return jsonify({'Predicted_Sales': predicted_sales}) |
| | except Exception as e: |
| | return jsonify({'error': str(e)}), 400 |
| | |
| |
|
| |
|
| | |
| | @sales_predictor_api.route('/v1/salesbatch', methods=['POST']) |
| | def predict_sales_batch(): |
| | """ |
| | Expects uploaded CSV file with all required features and an 'id' column. |
| | Returns a JSON dict of {id: predicted_sales} for all entries. |
| | """ |
| | try: |
| | file = request.files['file'] |
| | input_df = pd.read_csv(file) |
| |
|
| | |
| | preds = model.predict(input_df).tolist() |
| | preds_rounded = [round(float(p), 2) for p in preds] |
| |
|
| | |
| | ids = input_df['Product_Id'].tolist() |
| | results = dict(zip(ids, preds_rounded)) |
| |
|
| | return jsonify(results) |
| |
|
| | except Exception as e: |
| | return jsonify({"error": str(e)}), 400 |
| |
|
| | |
| | if __name__ == "__main__": |
| | sales_predictor_api.run(debug=True) |
| |
|