| |
| import numpy as np |
| import joblib |
| import pandas as pd |
| from flask import Flask, request, jsonify |
|
|
| |
| sales_revenue_predictor_api = Flask("Superkart sales Revenue Predictor") |
|
|
| |
| model = joblib.load("Sales_revenue_prediction_model_v1_0.joblib") |
|
|
| |
| @sales_revenue_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 SuperKart Sales revenue Prediction API!" |
|
|
| |
| @sales_revenue_predictor_api.post('/v1/sales') |
| def predict_product_sales(): |
| """ |
| This function handles POST requests to the '/v1/sales' endpoint. |
| It expects a JSON payload containing property details and returns |
| the predicted product total sales revenue as a JSON response. |
| """ |
| |
| sales_data = request.get_json() |
|
|
| |
| sample = { |
| 'Product_Weight': sales_data['Product_Weight'], |
| 'Product_Sugar_Content': sales_data['Product_Sugar_Content'], |
| 'Product_Allocated_Area': sales_data['Product_Allocated_Area'], |
| 'Product_Type': sales_data['Product_Type'], |
| 'Product_MRP': sales_data['Product_MRP'], |
| 'Store_Id': sales_data['Store_Id'], |
| 'Store_Establishment_Year': sales_data['Store_Establishment_Year'], |
| 'Store_Size': sales_data['Store_Size'], |
| 'Store_Location_City_Type': sales_data['Store_Location_City_Type'], |
| 'Store_Type': sales_data['Store_Type'] |
| } |
|
|
| |
| input_data = pd.DataFrame([sample]) |
|
|
| |
| predicted_Sales = model.predict(input_data)[0] |
|
|
| |
| predicted_product_sales = np.exp(predicted_Sales) |
|
|
| |
| predicted_product_sales = round(float(predicted_product_sales), 2) |
| |
| |
|
|
| |
| return jsonify({'Predicted total product sales': predicted_product_sales}) |
|
|
|
|
| |
| @sales_revenue_predictor_api.post('/v1/salesbatch') |
| def predict_product_sales_batch(): |
| """ |
| This function handles POST requests to the '/v1/salesbatch' endpoint. |
| It expects a CSV file containing property details for multiple properties |
| and returns the predicted total product sales revenue as a dictionary in the JSON response. |
| """ |
| |
| file = request.files['file'] |
|
|
| |
| input_data = pd.read_csv(file) |
|
|
| |
| predicted_Sales = model.predict(input_data).tolist() |
|
|
| |
| predicted_Sales = [round(float(np.exp(Product_Store_Sales_Total)), 2) for Product_Store_Sales_Total in predicted_Sales] |
|
|
| |
| Product_Ids = input_data['Product_Id'].tolist() |
| output_dict = dict(zip(Product_Ids, predicted_Sales)) |
|
|
| |
| return output_dict |
|
|
| |
| if __name__ == '__main__': |
| sales_revenue_predictor_api.run(debug=True) |
|
|