

{"id":145332,"date":"2025-06-18T11:04:02","date_gmt":"2025-06-18T05:34:02","guid":{"rendered":"https:\/\/data-flair.training\/blogs\/?p=145332"},"modified":"2025-06-18T11:04:02","modified_gmt":"2025-06-18T05:34:02","slug":"sales-data-analytics-using-python","status":"publish","type":"post","link":"https:\/\/data-flair.training\/blogs\/sales-data-analytics-using-python\/","title":{"rendered":"Python Project &#8211; Sales Data Analytics"},"content":{"rendered":"<h3>Program 1<\/h3>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\">import mysql.connector\r\nfrom tabulate import tabulate\r\n\r\n# Database connection\r\ndef connect_db():\r\n    return mysql.connector.connect(\r\n        host=\"localhost\",\r\n        user=\"root\",\r\n        password=\"root\",\r\n        database=\"sales_db\"\r\n    )\r\n\r\n# 1. View Total Revenue\r\ndef view_total_revenue(conn):\r\n    cursor = conn.cursor()\r\n    query = \"\"\"\r\n        SELECT SUM(p.price * s.quantity) AS total_revenue\r\n        FROM sales s\r\n        JOIN products p ON s.product_id = p.product_id\r\n    \"\"\"\r\n    cursor.execute(query)\r\n    result = cursor.fetchone()\r\n    print(\"\\nTotal Revenue: \u20b9\", result[0] if result[0] else 0)\r\n\r\n# 2. View Top Selling Products\r\ndef top_selling_products(conn):\r\n    cursor = conn.cursor()\r\n    query = \"\"\"\r\n        SELECT p.product_name, SUM(s.quantity) AS total_sold\r\n        FROM sales s\r\n        JOIN products p ON s.product_id = p.product_id\r\n        GROUP BY p.product_name\r\n        ORDER BY total_sold DESC\r\n        LIMIT 5\r\n    \"\"\"\r\n    cursor.execute(query)\r\n    rows = cursor.fetchall()\r\n    print(\"\\nTop Selling Products:\")\r\n    print(tabulate(rows, headers=[\"Product Name\", \"Total Sold\"], tablefmt=\"pretty\"))\r\n\r\n# 3. View Monthly Sales Report\r\ndef monthly_sales_report(conn):\r\n    cursor = conn.cursor()\r\n    query = \"\"\"\r\n        SELECT DATE_FORMAT(sale_date, '%Y-%m') AS month, SUM(p.price * s.quantity) AS revenue\r\n        FROM sales s\r\n        JOIN products p ON s.product_id = p.product_id\r\n        GROUP BY month\r\n        ORDER BY month\r\n    \"\"\"\r\n    cursor.execute(query)\r\n    rows = cursor.fetchall()\r\n    print(\"\\nMonthly Sales Report:\")\r\n    print(tabulate(rows, headers=[\"Month\", \"Revenue\"], tablefmt=\"pretty\"))\r\n\r\n# 4. City-wise Customer Count\r\ndef city_wise_customer_count(conn):\r\n    cursor = conn.cursor()\r\n    query = \"\"\"\r\n        SELECT city, COUNT(*) AS customer_count\r\n        FROM customers\r\n        GROUP BY city\r\n        ORDER BY customer_count DESC\r\n    \"\"\"\r\n    cursor.execute(query)\r\n    rows = cursor.fetchall()\r\n    print(\"\\nCity-wise Customer Count:\")\r\n    print(tabulate(rows, headers=[\"City\", \"Customer Count\"], tablefmt=\"pretty\"))\r\n\r\n# 5. Add New Customer\r\ndef add_new_customer(conn):\r\n    cursor = conn.cursor()\r\n    print(\"\\nEnter Customer Details:\")\r\n    customer_id = int(input(\"Customer ID: \"))\r\n    name = input(\"Name: \")\r\n    email = input(\"Email: \")\r\n    city = input(\"City: \")\r\n    registration_date = input(\"Registration Date (YYYY-MM-DD): \")\r\n\r\n    query = \"\"\"\r\n        INSERT INTO customers (customer_id, name, email, city, registration_date)\r\n        VALUES (%s, %s, %s, %s, %s)\r\n    \"\"\"\r\n    cursor.execute(query, (customer_id, name, email, city, registration_date))\r\n    conn.commit()\r\n    print(\"Customer added successfully!\")\r\n\r\n# 6. Add New Product\r\ndef add_new_product(conn):\r\n    cursor = conn.cursor()\r\n    print(\"\\nEnter Product Details:\")\r\n    product_id = int(input(\"Product ID: \"))\r\n    product_name = input(\"Product Name: \")\r\n    category = input(\"Category: \")\r\n    price = float(input(\"Price: \"))\r\n\r\n    query = \"\"\"\r\n        INSERT INTO products (product_id, product_name, category, price)\r\n        VALUES (%s, %s, %s, %s)\r\n    \"\"\"\r\n    cursor.execute(query, (product_id, product_name, category, price))\r\n    conn.commit()\r\n    print(\"Product added successfully!\")\r\n\r\n# 7. Add New Sale\r\ndef add_new_sale(conn):\r\n    cursor = conn.cursor()\r\n    print(\"\\nEnter Sale Details:\")\r\n    sale_id = int(input(\"Sale ID: \"))\r\n    customer_id = int(input(\"Customer ID: \"))\r\n    product_id = int(input(\"Product ID: \"))\r\n    quantity = int(input(\"Quantity: \"))\r\n    sale_date = input(\"Sale Date (YYYY-MM-DD): \")\r\n\r\n    query = \"\"\"\r\n        INSERT INTO sales (sale_id, customer_id, product_id, quantity, sale_date)\r\n        VALUES (%s, %s, %s, %s, %s)\r\n    \"\"\"\r\n    cursor.execute(query, (sale_id, customer_id, product_id, quantity, sale_date))\r\n    conn.commit()\r\n    print(\"Sale record added successfully!\")\r\n\r\n# Main menu\r\ndef main():\r\n    conn = connect_db()\r\n    while True:\r\n        print(\"\\n------ Sales Data Analytics Menu ------\")\r\n        print(\"1. View Total Revenue\")\r\n        print(\"2. View Top Selling Products\")\r\n        print(\"3. View Monthly Sales Report\")\r\n        print(\"4. View City-wise Customer Count\")\r\n        print(\"5. Add New Customer\")\r\n        print(\"6. Add New Product\")\r\n        print(\"7. Add New Sale\")\r\n        print(\"8. Exit\")\r\n        print(\"----------------------------------------------\")\r\n        choice = input(\"Enter your choice (1-8): \")\r\n\r\n        if choice == '1':\r\n            view_total_revenue(conn)\r\n        elif choice == '2':\r\n            top_selling_products(conn)\r\n        elif choice == '3':\r\n            monthly_sales_report(conn)\r\n        elif choice == '4':\r\n            city_wise_customer_count(conn)\r\n        elif choice == '5':\r\n            add_new_customer(conn)\r\n        elif choice == '6':\r\n            add_new_product(conn)\r\n        elif choice == '7':\r\n            add_new_sale(conn)\r\n        elif choice == '8':\r\n            print(\"********Exiting the program. Thank you!*******\")\r\n            break\r\n        else:\r\n            print(\"xxxxx  Invalid choice. Please try again. xxxxx\")\r\n\r\n    conn.close()\r\n\r\n# Main Calling\r\n\r\nmain()<\/pre>\n<p>&nbsp;<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Program 1 import mysql.connector from tabulate import tabulate # Database connection def connect_db(): return mysql.connector.connect( host=&#8221;localhost&#8221;, user=&#8221;root&#8221;, password=&#8221;root&#8221;, database=&#8221;sales_db&#8221; ) # 1. View Total Revenue def view_total_revenue(conn): cursor = conn.cursor() query = &#8220;&#8221;&#8221; SELECT&#46;&#46;&#46;<\/p>\n","protected":false},"author":581,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[46],"tags":[10333,28626,22366,34435,21082,34432,34434,34433,34431],"class_list":["post-145332","post","type-post","status-publish","format-standard","hentry","category-python","tag-python","tag-python-practical","tag-python-program","tag-python-program-on-sales-data-analytics","tag-python-project","tag-python-sales-data-analytics-project","tag-sales-data-analytics","tag-sales-data-analytics-project","tag-sales-data-analytics-using-python"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.4 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Python Project - Sales Data Analytics - DataFlair<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/data-flair.training\/blogs\/sales-data-analytics-using-python\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Python Project - Sales Data Analytics - DataFlair\" \/>\n<meta property=\"og:description\" content=\"Program 1 import mysql.connector from tabulate import tabulate # Database connection def connect_db(): return mysql.connector.connect( host=&quot;localhost&quot;, user=&quot;root&quot;, password=&quot;root&quot;, database=&quot;sales_db&quot; ) # 1. View Total Revenue def view_total_revenue(conn): cursor = conn.cursor() query = &quot;&quot;&quot; SELECT&#046;&#046;&#046;\" \/>\n<meta property=\"og:url\" content=\"https:\/\/data-flair.training\/blogs\/sales-data-analytics-using-python\/\" \/>\n<meta property=\"og:site_name\" content=\"DataFlair\" \/>\n<meta property=\"article:publisher\" content=\"https:\/\/www.facebook.com\/DataFlairWS\/\" \/>\n<meta property=\"article:published_time\" content=\"2025-06-18T05:34:02+00:00\" \/>\n<meta name=\"author\" content=\"DataFlair Team\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:creator\" content=\"@DataFlairWS\" \/>\n<meta name=\"twitter:site\" content=\"@DataFlairWS\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"DataFlair Team\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"1 minute\" \/>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Python Project - Sales Data Analytics - DataFlair","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/data-flair.training\/blogs\/sales-data-analytics-using-python\/","og_locale":"en_US","og_type":"article","og_title":"Python Project - Sales Data Analytics - DataFlair","og_description":"Program 1 import mysql.connector from tabulate import tabulate # Database connection def connect_db(): return mysql.connector.connect( host=\"localhost\", user=\"root\", password=\"root\", database=\"sales_db\" ) # 1. View Total Revenue def view_total_revenue(conn): cursor = conn.cursor() query = \"\"\" SELECT&#46;&#46;&#46;","og_url":"https:\/\/data-flair.training\/blogs\/sales-data-analytics-using-python\/","og_site_name":"DataFlair","article_publisher":"https:\/\/www.facebook.com\/DataFlairWS\/","article_published_time":"2025-06-18T05:34:02+00:00","author":"DataFlair Team","twitter_card":"summary_large_image","twitter_creator":"@DataFlairWS","twitter_site":"@DataFlairWS","twitter_misc":{"Written by":"DataFlair Team","Est. reading time":"1 minute"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/data-flair.training\/blogs\/sales-data-analytics-using-python\/#article","isPartOf":{"@id":"https:\/\/data-flair.training\/blogs\/sales-data-analytics-using-python\/"},"author":{"name":"DataFlair Team","@id":"https:\/\/data-flair.training\/blogs\/#\/schema\/person\/c187795dc82ab948373cca526df7c445"},"headline":"Python Project &#8211; Sales Data Analytics","datePublished":"2025-06-18T05:34:02+00:00","mainEntityOfPage":{"@id":"https:\/\/data-flair.training\/blogs\/sales-data-analytics-using-python\/"},"wordCount":8,"commentCount":0,"publisher":{"@id":"https:\/\/data-flair.training\/blogs\/#organization"},"keywords":["Python","python practical","python program","python program on sales data analytics","Python project","python sales data analytics project","sales data analytics","sales data analytics project","sales data analytics using python"],"articleSection":["Python Tutorials"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/data-flair.training\/blogs\/sales-data-analytics-using-python\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/data-flair.training\/blogs\/sales-data-analytics-using-python\/","url":"https:\/\/data-flair.training\/blogs\/sales-data-analytics-using-python\/","name":"Python Project - Sales Data Analytics - DataFlair","isPartOf":{"@id":"https:\/\/data-flair.training\/blogs\/#website"},"datePublished":"2025-06-18T05:34:02+00:00","breadcrumb":{"@id":"https:\/\/data-flair.training\/blogs\/sales-data-analytics-using-python\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/data-flair.training\/blogs\/sales-data-analytics-using-python\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/data-flair.training\/blogs\/sales-data-analytics-using-python\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Blog Home","item":"https:\/\/data-flair.training\/blogs\/"},{"@type":"ListItem","position":2,"name":"Python Tutorials","item":"https:\/\/data-flair.training\/blogs\/category\/python\/"},{"@type":"ListItem","position":3,"name":"Python Project &#8211; Sales Data Analytics"}]},{"@type":"WebSite","@id":"https:\/\/data-flair.training\/blogs\/#website","url":"https:\/\/data-flair.training\/blogs\/","name":"DataFlair","description":"Learn Today. Lead Tomorrow.","publisher":{"@id":"https:\/\/data-flair.training\/blogs\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/data-flair.training\/blogs\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Organization","@id":"https:\/\/data-flair.training\/blogs\/#organization","name":"DataFlair","url":"https:\/\/data-flair.training\/blogs\/","logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/data-flair.training\/blogs\/#\/schema\/logo\/image\/","url":"https:\/\/data-flair.training\/blogs\/wp-content\/uploads\/sites\/2\/2016\/07\/Data-Flair.png","contentUrl":"https:\/\/data-flair.training\/blogs\/wp-content\/uploads\/sites\/2\/2016\/07\/Data-Flair.png","width":106,"height":48,"caption":"DataFlair"},"image":{"@id":"https:\/\/data-flair.training\/blogs\/#\/schema\/logo\/image\/"},"sameAs":["https:\/\/www.facebook.com\/DataFlairWS\/","https:\/\/x.com\/DataFlairWS","https:\/\/www.linkedin.com\/company\/dataflair-web-services-pvt-ltd\/","https:\/\/www.youtube.com\/user\/DataFlairWS"]},{"@type":"Person","@id":"https:\/\/data-flair.training\/blogs\/#\/schema\/person\/c187795dc82ab948373cca526df7c445","name":"DataFlair Team","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/secure.gravatar.com\/avatar\/2302ebc438084d2f1f993edc1996a0aae01332e81f3227cba8df0c48ec010ca4?s=96&d=mm&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/2302ebc438084d2f1f993edc1996a0aae01332e81f3227cba8df0c48ec010ca4?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/2302ebc438084d2f1f993edc1996a0aae01332e81f3227cba8df0c48ec010ca4?s=96&d=mm&r=g","caption":"DataFlair Team"},"description":"DataFlair Team provides high-impact content on programming, Java, Python, C++, DSA, AI, ML, data Science, Android, Flutter, MERN, Web Development, and technology. We make complex concepts easy to grasp, helping learners of all levels succeed in their tech careers.","url":"https:\/\/data-flair.training\/blogs\/author\/dfteam6\/"}]}},"amp_enabled":true,"_links":{"self":[{"href":"https:\/\/data-flair.training\/blogs\/wp-json\/wp\/v2\/posts\/145332","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/data-flair.training\/blogs\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/data-flair.training\/blogs\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/data-flair.training\/blogs\/wp-json\/wp\/v2\/users\/581"}],"replies":[{"embeddable":true,"href":"https:\/\/data-flair.training\/blogs\/wp-json\/wp\/v2\/comments?post=145332"}],"version-history":[{"count":3,"href":"https:\/\/data-flair.training\/blogs\/wp-json\/wp\/v2\/posts\/145332\/revisions"}],"predecessor-version":[{"id":145351,"href":"https:\/\/data-flair.training\/blogs\/wp-json\/wp\/v2\/posts\/145332\/revisions\/145351"}],"wp:attachment":[{"href":"https:\/\/data-flair.training\/blogs\/wp-json\/wp\/v2\/media?parent=145332"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/data-flair.training\/blogs\/wp-json\/wp\/v2\/categories?post=145332"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/data-flair.training\/blogs\/wp-json\/wp\/v2\/tags?post=145332"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}