基于LibreOffice +python 实现一个小型销售管理系统的数据库原型教学实验

项目概述

本项目使用 SQLite 数据库和 LibreOffice 创建了一个完整的销售管理系统数据库,包含客户、商品、订单等数据,并生成了所需的报表。

创建一个 销售管理系统数据库 ,主要用于:

主要用途

1. 教学实验

这是 Week 5 数据库实验课 的作业,目的是学习如何:

  • 创建数据库表(客户、商品、订单等)
  • 编写 SQL 查询
  • 生成报表

2. 业务数据管理

系统可以管理:

  • 客户信息 - 公司名称、联系方式、地址等
  • 商品目录 - 商品名称、价格、库存等
  • 订单处理 - 订单状态(已完成/待处理)、发货信息等
  • 利润计算 - 每笔订单的利润分析

3. 报表生成

可以生成以下报表:

报表 用途 Customer Item List 客户商品目录 Profit by Order & Item 订单利润分析 Item Profit Summary 商品销售汇总

4. 数据分析

可以分析:

  • 哪些商品卖得最好
  • 哪些商品利润最高
  • 销售额和利润趋势

文件说明

数据库文件

  • Week5_Database.odb - LibreOffice Base 数据库文件,包含了所有表和查询

Python 脚本

文件 用途
create_database.py 创建数据库结构、表、插入示例数据、创建查询
export_csv.py 将查询结果导出为 CSV 文件
verify_data.py 验证数据库内容和查询结果

输出文件

文件 说明
Customer_Item_List.pdf 客户商品列表报表 (STEP 1)
Profit_By_Order_Item.pdf 订单利润报表 (STEP 2)
Item_Profit_Summary.pdf 商品利润汇总报表 (STEP 3)

数据库结构

表 (Tables)

  1. Customer - 客户表

    • CustomerID, CompanyName, ContactName, ContactTitle, Address, City, Region, PostalCode, Country, Phone, Fax
  2. Category - 商品类别表

    • CategoryID, CategoryName, Description
  3. Item - 商品表

    • ItemID, ItemName, CategoryID, UnitPrice, UnitsInStock, UnitsOnOrder, ReorderLevel, Discontinued
  4. Order - 订单表

    • OrderID, CustomerID, OrderDate, RequiredDate, ShippedDate, ShipVia, Freight, ShipName, ShipAddress, ShipCity, ShipRegion, ShipPostalCode, ShipCountry, OrderStatus
  5. Order Detail - 订单明细表

    • OrderDetailID, OrderID, ItemID, UnitPrice, Quantity, Discount

查询 (Queries)

  1. Customer Item List - 客户商品列表查询

    • 显示所有客户和商品的交叉列表
  2. Profit by Order & Item - 按订单和商品计算利润

    • 显示已完成订单的利润详情
  3. Order Detail Query - 订单明细查询

    • 用于汇总分析的详细数据
  4. Item Profit Summary - 商品利润汇总

    • 按商品汇总销量和利润

使用方法

1. 重新创建数据库

bash 复制代码
python3 create_database.py

2. 导出查询结果为 CSV

bash 复制代码
python3 export_csv.py

3. 验证数据

bash 复制代码
python3 verify_data.py

4. 使用 LibreOffice 打开数据库

bash 复制代码
"C:\Program Files\LibreOffice\program\soffice.exe" "Week5_Database.odb"

5. 将 CSV 转换为 Excel

bash 复制代码
"C:\Program Files\LibreOffice\program\soffice.exe" --headless --invisible --convert-to xlsx input.csv --outdir output_dir

6. 将 Excel 转换为 PDF

bash 复制代码
"C:\Program Files\LibreOffice\program\soffice.exe" --headless --invisible --convert-to pdf input.xlsx --outdir output_dir

数据分析结果

根据 STEP 3 的要求,系统可以分析以下内容:

  • 销量最高的商品
  • 销量最低的商品
  • 利润最高的商品
  • 利润最低的商品

环境要求

  • Python 3.x
  • LibreOffice 26.x
  • pypdf 库 (用于 PDF 处理)

安装依赖

bash 复制代码
pip install pypdf
相关推荐
HappyAcmen3 分钟前
2.lcut返回列表用法
python
Json____7 分钟前
Python练习题集-文件处理、数据管理与网络编程实战小项目15个
python·编程·编程学习·练习题·python学习
星空椰13 分钟前
Python 使用飞书 API 获取部门直属用户列表(递归获取所有部门 + 导出 Excel)
python·飞书
l1t17 分钟前
在aarch64机器上安装clang来生成codonjit python模块
开发语言·python
辰尘_星启31 分钟前
【Linux】Python Socket编程指南
linux·python·socket·系统·通信
南宫萧幕40 分钟前
基于 Simulink 与 Python 联合仿真的 eVTOL 强化学习全链路实战
开发语言·人工智能·python·算法·机器学习·控制
Amctwd1 小时前
【Python】从Excel中按行提取图片
java·python·excel
环流_1 小时前
Redis中string类型的应用场景
数据库·redis·缓存
倔强的石头_1 小时前
拒绝被复杂报表拖垮!HTAP场景下“标量子查询消除”硬核调优指南
数据库
张二娃同学1 小时前
第08篇_RNN_LSTM_GRU序列模型
人工智能·python·rnn·深度学习·神经网络·gru·lstm