{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Combined Expense Analysis (Flag 91)\n",
    "\n",
    "### Dataset Description\n",
    "The dataset consists of 500 entries simulating the ServiceNow fm_expense_line table, which records various attributes of financial expenses. Key fields include 'number', 'opened_at', 'amount', 'state', 'short_description', 'ci', 'user', 'department', 'category', 'processed_date', 'source_id', and 'type'. This table documents the flow of financial transactions by detailing the amount, departmental allocation, and the nature of each expense. It provides a comprehensive view of organizational expenditures across different categories, highlighting both the timing and the approval state of each financial entry. Additionally, the dataset includes insights into recurring expenses, the impact of keywords in short descriptions, and state-based processing efficiencies.\n",
    "\n",
    "### Your Task\n",
    "**Goal**: To analyze and understand the patterns and behaviors in expense processing, focusing on how different states, descriptive keywords, and recurring expenses influence financial operations. The aim is to provide actionable insights to improve workflow efficiency, budgetary control, and overall financial management.\n",
    "\n",
    "**Role**: Financial Operations Analyst\n",
    "\n",
    "**Difficulty**: 3 out of 5\n",
    "\n",
    "**Category**: Finance Management"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Import Necessary Libraries\n",
    "This cell imports all necessary libraries required for the analysis. This includes libraries for data manipulation, data visualization, and any specific utilities needed for the tasks. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import argparse\n",
    "import pandas as pd\n",
    "import json\n",
    "import requests\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "from pandas import date_range"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Load Dataset\n",
    "Loads the dataset needed for the expense analysis. The data is sourced from a CSV file and the process involves reading the file into a DataFrame to facilitate further plotting. This also checks the initial few rows to verify the correct loading of the data."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>category</th>\n",
       "      <th>state</th>\n",
       "      <th>closed_at</th>\n",
       "      <th>opened_at</th>\n",
       "      <th>closed_by</th>\n",
       "      <th>number</th>\n",
       "      <th>sys_updated_by</th>\n",
       "      <th>location</th>\n",
       "      <th>assigned_to</th>\n",
       "      <th>caller_id</th>\n",
       "      <th>sys_updated_on</th>\n",
       "      <th>short_description</th>\n",
       "      <th>priority</th>\n",
       "      <th>assignement_group</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Database</td>\n",
       "      <td>Closed</td>\n",
       "      <td>2023-07-25 03:32:18.462401146</td>\n",
       "      <td>2023-01-02 11:04:00</td>\n",
       "      <td>Fred Luddy</td>\n",
       "      <td>INC0000000034</td>\n",
       "      <td>admin</td>\n",
       "      <td>Australia</td>\n",
       "      <td>Fred Luddy</td>\n",
       "      <td>ITIL User</td>\n",
       "      <td>2023-07-06 03:31:13.838619495</td>\n",
       "      <td>There was an issue</td>\n",
       "      <td>2 - High</td>\n",
       "      <td>Database</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Hardware</td>\n",
       "      <td>Closed</td>\n",
       "      <td>2023-03-11 13:42:59.511508874</td>\n",
       "      <td>2023-01-03 10:19:00</td>\n",
       "      <td>Charlie Whitherspoon</td>\n",
       "      <td>INC0000000025</td>\n",
       "      <td>admin</td>\n",
       "      <td>India</td>\n",
       "      <td>Beth Anglin</td>\n",
       "      <td>Don Goodliffe</td>\n",
       "      <td>2023-05-19 04:22:50.443252112</td>\n",
       "      <td>There was an issue</td>\n",
       "      <td>1 - Critical</td>\n",
       "      <td>Hardware</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Database</td>\n",
       "      <td>Resolved</td>\n",
       "      <td>2023-01-20 14:37:18.361510788</td>\n",
       "      <td>2023-01-04 06:37:00</td>\n",
       "      <td>Charlie Whitherspoon</td>\n",
       "      <td>INC0000000354</td>\n",
       "      <td>system</td>\n",
       "      <td>India</td>\n",
       "      <td>Fred Luddy</td>\n",
       "      <td>ITIL User</td>\n",
       "      <td>2023-02-13 08:10:20.378839709</td>\n",
       "      <td>There was an issue</td>\n",
       "      <td>2 - High</td>\n",
       "      <td>Database</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Hardware</td>\n",
       "      <td>Resolved</td>\n",
       "      <td>2023-01-25 20:46:13.679914432</td>\n",
       "      <td>2023-01-04 06:53:00</td>\n",
       "      <td>Fred Luddy</td>\n",
       "      <td>INC0000000023</td>\n",
       "      <td>admin</td>\n",
       "      <td>Canada</td>\n",
       "      <td>Luke Wilson</td>\n",
       "      <td>Don Goodliffe</td>\n",
       "      <td>2023-06-14 11:45:24.784548040</td>\n",
       "      <td>There was an issue</td>\n",
       "      <td>2 - High</td>\n",
       "      <td>Hardware</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Hardware</td>\n",
       "      <td>Closed</td>\n",
       "      <td>2023-05-10 22:35:58.881919516</td>\n",
       "      <td>2023-01-05 16:52:00</td>\n",
       "      <td>Luke Wilson</td>\n",
       "      <td>INC0000000459</td>\n",
       "      <td>employee</td>\n",
       "      <td>UK</td>\n",
       "      <td>Charlie Whitherspoon</td>\n",
       "      <td>David Loo</td>\n",
       "      <td>2023-06-11 20:25:35.094482408</td>\n",
       "      <td>There was an issue</td>\n",
       "      <td>2 - High</td>\n",
       "      <td>Hardware</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   category     state                      closed_at            opened_at  \\\n",
       "0  Database    Closed  2023-07-25 03:32:18.462401146  2023-01-02 11:04:00   \n",
       "1  Hardware    Closed  2023-03-11 13:42:59.511508874  2023-01-03 10:19:00   \n",
       "2  Database  Resolved  2023-01-20 14:37:18.361510788  2023-01-04 06:37:00   \n",
       "3  Hardware  Resolved  2023-01-25 20:46:13.679914432  2023-01-04 06:53:00   \n",
       "4  Hardware    Closed  2023-05-10 22:35:58.881919516  2023-01-05 16:52:00   \n",
       "\n",
       "              closed_by         number sys_updated_by   location  \\\n",
       "0            Fred Luddy  INC0000000034          admin  Australia   \n",
       "1  Charlie Whitherspoon  INC0000000025          admin      India   \n",
       "2  Charlie Whitherspoon  INC0000000354         system      India   \n",
       "3            Fred Luddy  INC0000000023          admin     Canada   \n",
       "4           Luke Wilson  INC0000000459       employee         UK   \n",
       "\n",
       "            assigned_to      caller_id                 sys_updated_on  \\\n",
       "0            Fred Luddy      ITIL User  2023-07-06 03:31:13.838619495   \n",
       "1           Beth Anglin  Don Goodliffe  2023-05-19 04:22:50.443252112   \n",
       "2            Fred Luddy      ITIL User  2023-02-13 08:10:20.378839709   \n",
       "3           Luke Wilson  Don Goodliffe  2023-06-14 11:45:24.784548040   \n",
       "4  Charlie Whitherspoon      David Loo  2023-06-11 20:25:35.094482408   \n",
       "\n",
       "    short_description      priority assignement_group  \n",
       "0  There was an issue      2 - High          Database  \n",
       "1  There was an issue  1 - Critical          Hardware  \n",
       "2  There was an issue      2 - High          Database  \n",
       "3  There was an issue      2 - High          Hardware  \n",
       "4  There was an issue      2 - High          Hardware  "
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_path = \"csvs/flag-91.csv\"\n",
    "flag_data = pd.read_csv(dataset_path)\n",
    "df = pd.read_csv(dataset_path)\n",
    "flag_data.head()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "\n",
    "### **Question 1: What are the differences in processing times for expenses in various states such as Processed, Declined, Submitted, and Pending?**\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Analyzing the processing times for expenses in different states reveals notable differences. Processed expenses tend to have shorter processing times compared to Declined expenses. Understanding these differences helps identify areas for potential optimization and efficiency improvements in the expense processing workflow."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "N/A\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "# Load the combined dataset\n",
    "combined_file_path = 'csvs/flag-91.csv'\n",
    "data = pd.read_csv(combined_file_path)\n",
    "\n",
    "# # Convert the date columns to datetime type and calculate processing time\n",
    "# data['opened_at'] = pd.to_datetime(data['opened_at'])\n",
    "# data['processed_date'] = pd.to_datetime(data['processed_date'], errors='coerce')\n",
    "# data['processing_time_hours'] = (data['processed_date'] - data['opened_at']).dt.total_seconds() / 3600\n",
    "\n",
    "# # Calculate average processing time for each state\n",
    "# avg_processing_time_by_state = data.groupby('state')['processing_time_hours'].mean().reset_index()\n",
    "\n",
    "# # Set the style of the visualization\n",
    "# sns.set(style=\"whitegrid\")\n",
    "\n",
    "# # Create a bar plot for average processing time by state\n",
    "# plt.figure(figsize=(12, 6))\n",
    "# sns.barplot(x='state', y='processing_time_hours', data=avg_processing_time_by_state)\n",
    "# plt.title('Average Processing Time by State')\n",
    "# plt.xlabel('State')\n",
    "# plt.ylabel('Average Processing Time (hours)')\n",
    "# plt.xticks(rotation=45)\n",
    "# plt.show()\n",
    "print(\"N/A\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Generate JSON Description for the Insight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'comparative',\n",
       " 'insight': \"Analysis could not be completed due to missing 'processed_date' column in the dataset\",\n",
       " 'insight_value': {},\n",
       " 'plot': {'description': 'A bar plot was attempted to show average processing times by state, but failed due to missing data column'},\n",
       " 'question': 'What are the differences in processing times for expenses in various states such as Processes, Declined, Submitted, and Pending?',\n",
       " 'actionable_insight': 'No actionable insight could be generated due to missing data column'}"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"comparative\",\n",
    "    \"insight\": \"Analysis could not be completed due to missing 'processed_date' column in the dataset\",\n",
    "    \"insight_value\": {},\n",
    "    \"plot\": {\n",
    "        \"description\": \"A bar plot was attempted to show average processing times by state, but failed due to missing data column\"\n",
    "    },\n",
    "    \"question\": \"What are the differences in processing times for expenses in various states such as Processes, Declined, Submitted, and Pending?\",\n",
    "    \"actionable_insight\": \"No actionable insight could be generated due to missing data column\"\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 2:  How do specific keywords in the short descriptions of expense reports influence the amount of these expenses?**\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Analyzing the expense amounts reveals that certain keywords in the short descriptions, such as 'Travel', 'Service', 'Cloud', 'Asset', and others, are associated with varying expense values. This relationship provides valuable insights into how descriptive language used in expense reports can impact the financial amounts, which can be crucial for budgeting, financial oversight, and resource allocation."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "N/A\n"
     ]
    }
   ],
   "source": [
    "# # Function to categorize descriptions based on keywords\n",
    "# def categorize_description(description):\n",
    "#     keywords = {\"Travel\": 1.5, \"Service\": 1.2, \"Cloud\": 1.3, \"Asset\": 0.8, \"Equipment\": 0.9}\n",
    "#     for keyword in keywords.keys():\n",
    "#         if pd.notnull(description) and keyword in description:\n",
    "#             return keyword\n",
    "#     return 'Other'\n",
    "\n",
    "# # Apply the function to create a new column for categories\n",
    "# data['description_category'] = data['short_description'].apply(categorize_description)\n",
    "\n",
    "# # Set the style of the visualization\n",
    "# sns.set(style=\"whitegrid\")\n",
    "\n",
    "# # Create a boxplot for amount by description category\n",
    "# plt.figure(figsize=(12, 6))\n",
    "# sns.boxplot(x='description_category', y='amount', data=data)\n",
    "# plt.title('Amount Distribution by Short Description Category')\n",
    "# plt.xlabel('Short Description Category')\n",
    "# plt.ylabel('Amount')\n",
    "# plt.xticks(rotation=45)\n",
    "# plt.show()\n",
    "print(\"N/A\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Generate JSON Description for the Insight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'comparative',\n",
       " 'insight': \"The analysis could not be completed due to a ValueError indicating that the 'amount' column is not present in the dataset\",\n",
       " 'insight_value': {},\n",
       " 'plot': {'description': \"A boxplot was attempted to show the distribution of expense amounts across different description categories, but failed due to missing 'amount' column in the data\"},\n",
       " 'question': 'How do specific keywords in the short descriptions of expense reports influence the amount of these expenses?',\n",
       " 'actionable_insight': 'No actionable insight could be generated due to missing data'}"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"comparative\",\n",
    "    \"insight\": \"The analysis could not be completed due to a ValueError indicating that the 'amount' column is not present in the dataset\",\n",
    "    \"insight_value\": {},\n",
    "    \"plot\": {\n",
    "        \"description\": \"A boxplot was attempted to show the distribution of expense amounts across different description categories, but failed due to missing 'amount' column in the data\"\n",
    "    },\n",
    "    \"question\": \"How do specific keywords in the short descriptions of expense reports influence the amount of these expenses?\",\n",
    "    \"actionable_insight\": \"No actionable insight could be generated due to missing data\"\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 3:  What are the expense patterns for different departments in terms of average amounts?**\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "By examining the average expense amounts across different departments, we can uncover departmental spending patterns. This can help in understanding which departments have higher or lower average expenses, providing insights for budgeting and resource allocation decisions."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "N/A\n"
     ]
    }
   ],
   "source": [
    "# # Calculate average amount for each department\n",
    "# avg_amount_by_department = data.groupby('department')['amount'].mean().reset_index()\n",
    "\n",
    "# # Set the style of the visualization\n",
    "# sns.set(style=\"whitegrid\")\n",
    "\n",
    "# # Create a bar plot for average amount by department\n",
    "# plt.figure(figsize=(12, 6))\n",
    "# sns.barplot(x='department', y='amount', data=avg_amount_by_department)\n",
    "# plt.title('Average Amount by Department')\n",
    "# plt.xlabel('Department')\n",
    "# plt.ylabel('Average Amount')\n",
    "# plt.xticks(rotation=45)\n",
    "# plt.show()\n",
    "print(\"N/A\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Generate JSON Description for the Insight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'comparative',\n",
       " 'insight': \"Analysis could not be performed due to missing 'department' column in the dataset\",\n",
       " 'insight_value': {},\n",
       " 'plot': {'description': \"Bar plot could not be generated due to KeyError indicating missing 'department' column\"},\n",
       " 'question': 'What are the expense patterns for different departments in terms of average amounts?',\n",
       " 'actionable_insight': 'Data quality issue needs to be addressed - verify the presence and correct naming of the department column in the dataset before analysis can proceed'}"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"comparative\",\n",
    "    \"insight\": \"Analysis could not be performed due to missing 'department' column in the dataset\",\n",
    "    \"insight_value\": {},\n",
    "    \"plot\": {\n",
    "        \"description\": \"Bar plot could not be generated due to KeyError indicating missing 'department' column\"\n",
    "    },\n",
    "    \"question\": \"What are the expense patterns for different departments in terms of average amounts?\",\n",
    "    \"actionable_insight\": \"Data quality issue needs to be addressed - verify the presence and correct naming of the department column in the dataset before analysis can proceed\"\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 4: How does the number of expense reports submitted vary by user?**\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Analyzing the number of expense reports submitted by different users can help identify the most active users in terms of expense submissions. This insight can aid in understanding user behavior and identifying potential areas for fraud detection or efficiency improvements."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "N/A\n"
     ]
    }
   ],
   "source": [
    "# # Calculate the number of expense reports submitted by each user\n",
    "# expense_reports_by_user = data['user'].value_counts().reset_index()\n",
    "# expense_reports_by_user.columns = ['user', 'number_of_reports']\n",
    "\n",
    "# # Set the style of the visualization\n",
    "# sns.set(style=\"whitegrid\")\n",
    "\n",
    "# # Create a bar plot for the number of expense reports by user\n",
    "# plt.figure(figsize=(12, 6))\n",
    "# sns.barplot(x='user', y='number_of_reports', data=expense_reports_by_user)\n",
    "# plt.title('Number of Expense Reports by User')\n",
    "# plt.xlabel('User')\n",
    "# plt.ylabel('Number of Expense Reports')\n",
    "# plt.xticks(rotation=90)\n",
    "# plt.show()\n",
    "print(\"N/A\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Generate JSON Description for the Insight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'comparative',\n",
       " 'insight': \"Analysis could not be performed because the 'user' column is missing from the dataset\",\n",
       " 'insight_value': {},\n",
       " 'plot': {'description': \"A bar plot was attempted to show the distribution of expense reports across users, but could not be generated due to missing 'user' column in the data\"},\n",
       " 'question': 'How does the number of expenses reports submitted vary by user?',\n",
       " 'actionable_insight': 'Data quality needs to be addressed - verify that the user information is properly included in the dataset before analysis can be performed'}"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "    \"data_type\": \"comparative\",\n",
    "    \"insight\": \"Analysis could not be performed because the 'user' column is missing from the dataset\",\n",
    "    \"insight_value\": {},\n",
    "    \"plot\": {\n",
    "        \"description\": \"A bar plot was attempted to show the distribution of expense reports across users, but could not be generated due to missing 'user' column in the data\"\n",
    "    },\n",
    "    \"question\": \"How does the number of expenses reports submitted vary by user?\",\n",
    "    \"actionable_insight\": \"Data quality needs to be addressed - verify that the user information is properly included in the dataset before analysis can be performed\"\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### **Question 5: What is the distribution of expense categories?**"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Examining the distribution of expense categories can provide insights into which types of expenses are most common. This information can be useful for understanding spending patterns and identifying areas for cost-saving opportunities or increased financial oversight."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA/EAAAJhCAYAAAAJ0DBiAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABxJklEQVR4nO3dd3hO9//H8dednQhBEKtG7ZEQW21VFFWpqr33VlGjZtWqGQS19wg1qkqLmlUrarViq51YESsy798ffrm/gtYKd448H9flupJzzn3u933nLblf53zO55jMZrNZAAAAAAAg0bOxdgEAAAAAAODFEOIBAAAAADAIQjwAAAAAAAZBiAcAAAAAwCAI8QAAAAAAGAQhHgAAAAAAgyDEAwAAAABgEIR4AAAAAAAMghAPADAks9ls7RISRQ0wDvoFAJAQCPEAgATXtGlT5cmTx/Ivb9688vb21meffaYFCxYoOjo63vaVK1dW3759X3j/v/32m/r06fPc7fr27avKlSu/8vP8mzt37qh3794KDAy0LGvatKmaNm362vtOKNHR0erbt6+8vb1VpEgR7dmz56ltLl26FO/n9Kx/S5cutUL1icPu3bvVpUsXlStXToUKFVK1atX03Xff6ebNmy+9rwMHDqhdu3ZvoMrXk9j6FgDwfHbWLgAA8G7Knz+/Bg8eLEmKiYlRWFiYduzYoZEjRyowMFB+fn6ysXl0LNnf31+urq4vvO958+a90HadOnVSs2bNXrr25wkKCtKPP/6ounXrWpbFvdbEYufOnVq9erU6deqkDz74QPnz5//XbTt27KiKFSs+c9177733hipM3MaOHatZs2apevXq6t+/v1KmTKkTJ05o5syZ2rhxoxYtWqQMGTK88P5WrFihM2fOvMGKX01i61sAwPMR4gEAb4Srq6sKFy4cb1nlypX1/vvva/jw4Vq3bp1q164tSf8ZMF9HlixZ3sh+nyVnzpxv7blexO3btyVJn3322XODeJYsWZ76WSVlP//8s2bOnKl+/fqpRYsWluWlSpVShQoV5OPjo+HDh8vf3996RSaQxNa3AIDnYzg9AOCtatKkiTw8PLRs2TLLsieHuccFfC8vL5UqVUq9evVSSEiIpEfDf/ft26d9+/YpT5482rt3r/bu3as8efJo2bJlqlSpkooUKaJdu3Y9NZxekqKiojRs2DAVL15c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QPXq1UvVqlVTkyZNLNfWSPFvN+fr66vLly9r2bJlT60DErtjx45pwIABypw5szp06KD8+fNrxowZmj17tuVSEUlav369Vq5cqZs3b2rSpEnKkiWLlSsHXt+zfl9v2LBBo0ePVpEiRdShQwflypVLW7du1cCBA5UtWzYtWrQo3mP5nQ8j2L17t7p06SKz2Sx3d3e999576tu3L7fawjsrPDycS5veYYR4/KcDBw6oe/fuqlWrVrxJMqT/fYAbMWKETp48qXnz5lmvUOA1BAUFqU+fPpZ7rP78888aO3asypYtG+864TVr1mjdunX65ptvmLQL75Rbt27FG3H166+/atiwYSpRooQ6deqkHDlyaNu2berQoYPq16+vb775RrGxsTKZTAR4GMalS5d048YNpUyZUu7u7vEuBQEAIyHE47n+LcibzWbFxsaqd+/eypw5s7788kvOyMCwgoKC1KtXL124cEF9+/ZV48aNLeseD/L37t3jbgt4pyxYsEAHDx5Up06d4t0be8OGDfr6669Vvnx5de3aVTlz5tSff/6pQoUKydbW1ooVAwCQtNk8fxMkdUWLFtXEiRO1bt06y33fpUezEU+aNEl//PGH6tSpY1kGGFG+fPk0fvx4ZcuWTYGBgfr7778t6+JmrZdEgIfhxU1SGsdsNmv37t1auHChTp06ZVn+8ccfq0OHDtq2bZsmTpyoc+fOqUiRIrK1tVVMTMzbLhsAAPw/QjxeyJNB/tatW5o2bZrmzp2rWbNmKXv27NYuEXhtefLk0ejRo3XmzBnNmDFDx44ds6zjABXeBWaz2TKqZMWKFZKk5s2by9fXV1u2bNG8efN08uRJy/YpU6aUl5eXMmXKpKxZs1qWcyYeAADrYTg9XsqBAwfUq1cvubq66uLFi1q0aJEKFixo7bKABBUUFKT+/fsrVapU+uqrr5Q3b15rlwS8tscvC7ly5Ypq1qypggULauHChZKk5cuXa9KkSapUqZJ8fHzk6empHj16qEyZMmrYsKFMJtNT95IHAABvHyEeL23//v3q0aOHZs+eTbjBO+vo0aMaOXKkJkyYIA8PD2uXAySYSZMm6a+//tLp06d15coVFSpUSAEBAZKkgIAAff/994qMjJSTk5McHR21du1a2dnZMecJAACJBCEer+Thw4dycnKydhnAGxURESFHR0drlwEkmIULF2ry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",
      "text/plain": [
       "<Figure size 1200x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Calculate the distribution of expense categories\n",
    "expense_categories_distribution = data['category'].value_counts().reset_index()\n",
    "expense_categories_distribution.columns = ['category', 'count']\n",
    "\n",
    "# Set the style of the visualization\n",
    "sns.set(style=\"whitegrid\")\n",
    "\n",
    "# Create a bar plot for the distribution of expense categories\n",
    "plt.figure(figsize=(12, 6))\n",
    "sns.barplot(x='category', y='count', data=expense_categories_distribution)\n",
    "plt.title('Distribution of Expense Categories')\n",
    "plt.xlabel('Category')\n",
    "plt.ylabel('Count')\n",
    "plt.xticks(rotation=45)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_type': 'descriptive',\n",
       " 'insight': 'The distribution shows no trend across IT expense categories',\n",
       " 'insight_value': {'description': 'All five expense categories (Database, Hardware, Inquiry/Help, Software, Network) have identical counts of 100'},\n",
       " 'plot': {'plot_type': 'bar',\n",
       "  'title': 'Distribution of Expense Categories',\n",
       "  'x_axis': {'name': 'Category',\n",
       "   'value': ['Database', 'Hardware', 'Inquiry/Help', 'Software', 'Network'],\n",
       "   'description': 'Five main IT expense categories'},\n",
       "  'y_axis': {'name': 'Count',\n",
       "   'value': 100,\n",
       "   'description': 'Each category shows exactly 100 counts'},\n",
       "  'description': 'Bar chart displaying uniform distribution with equal heights across all expense categories'},\n",
       " 'question': 'What is the distribution of expense categories?',\n",
       " 'actionable_insight': {'description': 'The uniform distribution indicates balanced resource allocation across IT categories, suggesting either standardized categorization or strategic equal distribution of resources'}}"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{\n",
    "   \"data_type\":\"descriptive\",\n",
    "   \"insight\":\"The distribution shows no trend across IT expense categories\",\n",
    "   \"insight_value\":{\n",
    "      \"description\":\"All five expense categories (Database, Hardware, Inquiry/Help, Software, Network) have identical counts of 100\"\n",
    "   },\n",
    "   \"plot\":{\n",
    "      \"plot_type\":\"bar\",\n",
    "      \"title\":\"Distribution of Expense Categories\",\n",
    "      \"x_axis\":{\n",
    "         \"name\":\"Category\",\n",
    "         \"value\":[\n",
    "            \"Database\",\n",
    "            \"Hardware\",\n",
    "            \"Inquiry/Help\",\n",
    "            \"Software\",\n",
    "            \"Network\"\n",
    "         ],\n",
    "         \"description\":\"Five main IT expense categories\"\n",
    "      },\n",
    "      \"y_axis\":{\n",
    "         \"name\":\"Count\",\n",
    "         \"value\":100,\n",
    "         \"description\":\"Each category shows exactly 100 counts\"\n",
    "      },\n",
    "      \"description\":\"Bar chart displaying uniform distribution with equal heights across all expense categories\"\n",
    "   },\n",
    "   \"question\":\"What is the distribution of expense categories?\",\n",
    "   \"actionable_insight\":{\n",
    "      \"description\":\"The uniform distribution indicates balanced resource allocation across IT categories, suggesting either standardized categorization or strategic equal distribution of resources\"\n",
    "   }\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Summary of Findings (Flag 91):\n",
    "\n",
    "1. **State-Based Processing Time Analysis**: The analysis could not be completed due to missing data in the 'processed_date' field. The missing values in this field prevented a comprehensive comparison of processing times across different states. To address this issue, data cleaning and imputation techniques can be applied to fill in the missing values and enable a more accurate analysis of processing times.\n",
    "\n",
    "2. **Impact of Keywords in Short Descriptions on Expense Amounts**: The dataset is missing required fields to perform a detailed analysis.\n",
    "\n",
    "3. **Recurring Expense Patterns**: The dataset is missing required fields to perform a detailed analysis."
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
