news 2026/5/15 1:27:03

Python +Vue实战:从零搭建中国电影票房数据可视化分析系统(附完整源码)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Python +Vue实战:从零搭建中国电影票房数据可视化分析系统(附完整源码)

Python+Vue实战:从零搭建中国电影票房数据可视化分析系统(附完整源码)

本文将带你从零开始,使用Python Flask + Vue3 + ECharts搭建一个完整的中国电影票房数据可视化分析系统。包含数据清洗、后端API开发、前端可视化大屏等全流程实现,适合作为全栈学习项目技术作品集展示


一、项目效果预览

1. 数据总览大屏

首页采用仪表盘布局,核心指标一目了然:

  • 电影总数: 2,871部
  • 累计票房总额: ¥5,262.55亿
  • 平均评分: 6.06分
  • 最高票房电影: 哪吒之魔童闹海 (154.46亿)

同时集成了年度票房趋势折线图电影类型分布饼图地区影片分布柱状图等多维度可视化。


2. 原始数据处理

项目基于真实的中国电影票房Excel数据进行处理,包含以下字段:

字段说明
片名电影中文名称
英文片名电影英文名称
类型剧情/喜剧/动作等
地区中国大陆/美国/日本等
上映日期上映时间
累计票房(万)总票房(万元)
首日票房(万)首日票房(万元)
首周票房(万)首周票房(万元)
评分观众评分
评分人数参评人数
想看人数预约观看人数

3. 电影信息管理

完整的CRUD功能

  • 多条件组合搜索(片名、类型、地区、上映年份)
  • 评分区间筛选、票房区间筛选
  • 实时统计卡片:总片数、高评分占比、高票房占比、平均票房
  • 支持查看详情、编辑、删除操作

4. 票房深度分析

四大分析维度

  1. 票房TOP10排行- 柱状图展示Top10电影累计票房(亿元单位)
  2. 首日/首周/累计对比- 堆叠柱状图,支持横向滚动浏览全部电影
  3. 预测vs实际偏差- 双柱+折线组合图,直观展示预测准确度
  4. 关键指标卡片- 平均票房、日均票房、偏差率等

5. 电影详情页

以《哪吒之魔童闹海》为例,详情页包含:

  • 基础信息卡片:海报、片名、上映时间、时长、导演、主演等
  • 票房数据面板:累计票房、首日票房、首周票房、最高单日、分账票房
  • 星级评分占比:环形图展示五星到一星的分布比例
  • 票房构成柱状图:首日/首周/最高单日/预测/实际/分账对比

6. 类型多维度分析

三种可视化视角

图表用途
类型数量分布饼图了解各类型影片占比
各类型平均票房柱状图发现高票房类型(动画12.91亿领先)
类型综合雷达图从影片数/票房/评分多角度评估

下方附带详细数据表格,支持排序查看。


7. 地区分析

  • 各地区影片数量分布:中国大陆以1909部遥遥领先
  • 各地区票房与评分双轴图:柱状图表示平均票房,折线图表示平均评分
  • 详细统计表:按地区汇总影片数、平均票房、平均评分

8. 年度趋势分析

综合趋势折线图+五维小图表矩阵

维度图表类型分析价值
年度综合趋势多系列折线图同时观察数量/票房/评分变化
影片数量变化面积图行业发展趋势
票房总额变化面积图市场规模演变
平均评分变化面积图质量趋势判断
平均票价变化面积图消费能力参考
想看人数变化面积图受众热度指标

二、技术架构

技术栈明细

层级技术版本用途
前端框架Vue.js3.xSPA应用
UI组件库Element Plus2.x企业级组件
状态管理Pinia2.x全局状态
图表库ECharts5.x数据可视化
HTTP客户端Axios1.xAPI请求
后端框架Flask3.xWeb服务
ORMSQLAlchemy3.x数据库操作
数据库SQLite3.x数据存储
认证Flask-JWT4.xJWT令牌认证
跨域Flask-CORS4.xCORS支持

三、核心功能模块

3.1 数据层设计

# Movie模型 (核心字段)classMovie(db.Model):id=db.Column(db.Integer,primary_key=True)movie_id=db.Column(db.String(50))# 电影唯一标识name=db.Column(db.String(200))# 片名english_name=db.Column(db.String(300))# 英文名genre=db.Column(db.String(100))# 类型region=db.Column(db.String(50))# 地区release_date=db.Column(db.String(100))# 上映日期total_box_office=db.Float)# 累计票房(万)opening_day_box_office=db.Float)# 首日票房(万)opening_week_box_office=db.Float)# 首周票房(万)predicted_box_office=db.Float)# 预测票房(万)rating=db.Float)# 评分rating_count=db.Integer)# 评分人数want_to_see_count=db.Integer)# 想看人数release_year=db.Integer)# 上映年份list_year=db.Integer)# 统计年份

3.2 API接口设计

/api/movies/ GET /list 获取电影列表(分页+筛选) GET /:id 获取电影详情 PUT /:id 更新电影信息 DELETE /:id 删除电影 /api/box-office/ GET /overview 票房概览统计 GET /top10 票房TOP10 GET /comparison 首日/首周/累计对比 GET /ranking 票房排行榜 /api/rating/ GET /top10 评分TOP10 GET /distribution 评分分布 GET /vs-box-office 评分vs票房散点图 GET /want-to-see/top10 想看人数TOP10 /api/analysis/ GET /genre 类型分析 GET /region 地区分析 GET /yearly-trend 年度趋势 /api/auth/ POST /register 用户注册 POST /login 用户登录 GET /me 获取当前用户 PUT /profile 更新个人信息 POST /avatar 上传头像 POST /change-password 修改密码

3.3 数据去重策略

针对同一电影可能多次上榜的问题,实现了智能去重

defget_deduped_query():"""获取去重后的查询,同一movie_id只保留最新记录"""subq=db.session.query(func.max(Movie.id).label('max_id')).group_by(Movie.movie_id).subquery()returnMovie.query.join(subq,Movie.id==subq.c.max_id)

3.4 单位转换处理

后端统一进行单位转换,前端直接展示:

# 后端转换逻辑'avg_total_box_office':round((stats.avg_totalor0)/10000,2)# 万元→亿元'rating_count':round((d['rating_count']or0)/10000,2)# 人→万人'want_to_see_count':round((d['want_to_see_count']or0)/10000,2)# 人→万人

四、项目目录结构

flask_project/ ├── backend/ # 后端代码 │ ├── app/ │ │ ├── __init__.py # Flask应用工厂 │ │ ├── app.py # 入口文件 │ │ ├── models/ │ │ │ ├── movie.py # 电影模型 │ │ │ └── user.py # 用户模型 │ │ ├── routes/ │ │ │ ├── auth_routes.py # 认证路由 │ │ │ ├── dashboard_routes.py # 仪表盘 │ │ │ ├── movie_routes.py # 电影CRUD │ │ │ ├── box_office_routes.py # 票房分析 │ │ │ ├── rating_routes.py # 评分分析 │ │ │ ├── analysis_routes.py # 分析接口 │ │ │ └── yearly_trend_routes.py # 年度趋势 │ │ └── utils/ │ │ └── data_cleaner.py # 数据清洗工具 │ ├── uploads/ │ │ └── avatars/ # 头像上传目录 │ ├── requirements.txt │ └── data/ │ └── movies.db # SQLite数据库 │ ├── frontend/ # 前端代码 │ ├── src/ │ │ ├── api/index.js # API封装 │ │ ├── components/ # 公共组件 │ │ │ └── Header.vue # 顶部导航 │ │ ├── views/ # 页面组件 │ │ │ ├── Dashboard.vue # 数据总览 │ │ │ ├── MovieList.vue # 电影列表 │ │ │ ├── MovieDetail.vue # 电影详情 │ │ │ ├── BoxOfficeAnalysis.vue # 票房分析 │ │ │ ├── RatingAnalysis.vue # 评分分析 │ │ │ ├── GenreAnalysis.vue # 类型分析 │ │ │ ├── RegionAnalysis.vue # 地区分析 │ │ │ ├── YearlyTrendAnalysis.vue# 年度趋势 │ │ │ ├── Login.vue # 登录注册 │ │ │ └── Profile.vue # 个人设置 │ │ ├── stores/auth.js # 认证状态 │ │ ├── router/index.js # 路由配置 │ │ └── main.js # 入口文件 │ ├── package.json │ └── vite.config.js │ ├── data/ │ └── 电影票房完整数据v1.0.xlsx # 原始数据 └── 发布文案.md

五、快速开始

5.1 环境要求

  • Python 3.9+
  • Node.js 16+
  • npm 或 pnpm

5.2 后端启动

cdbackend# 创建虚拟环境python-mvenv venv venv\Scripts\activate# 安装依赖pipinstall-rrequirements.txt# 导入数据(首次运行)flask import-data# 启动服务python app.py

访问:http://localhost:5000

5.3 前端启动

cdfrontend# 安装依赖npminstall# 启动开发服务器npmrun dev

访问:http://localhost:3000

5.4 默认账号

角色用户名密码
管理员adminadmin123

六、关键技术点解析

6.1 ECharts图表优化

滚动条初始位置修复

dataZoom:[{type:'slider',show:true,start:0,// 关键:从0开始,不是计算值end:data.length>15?Math.ceil(15/data.length*100):100}]

Tooltip格式化

tooltip:{formatter:function(params){return`${params[0].name}<br/>累计票房:<b>${params[0].value}</b> 亿元`}}

6.2 前端状态管理

使用Pinia管理全局认证状态:

// stores/auth.jsexportconstuseAuthStore=defineStore('auth',()=>{consttoken=ref(localStorage.getItem('token')||'')constuser=ref(JSON.parse(localStorage.getItem('user')||'null'))constisAdmin=computed(()=>user.value?.role==='admin')return{token,user,isAdmin,logout,fetchUser}})

6.3 文件上传处理

@auth_bp.route('/avatar',methods=['POST'])@jwt_required()defupload_avatar():file=request.files['avatar']# 格式校验allowed_extensions={'png','jpg','jpeg','gif','webp'}# 大小限制 2MB# UUID命名防冲突filename=f"{uuid4().hex}.{ext}"returnjsonify({'code':200,'data':{'avatar':f"/uploads/avatars/{filename}"}})

七、扩展方向

本项目还可以进一步扩展:

  • 实时数据接入:对接猫眼/淘票票API获取实时票房
  • 数据导出功能:支持导出Excel/PDF报告
  • 权限细化:不同角色看到不同的数据和功能
  • 数据预警:设置阈值,异常数据自动告警
  • 移动端适配:响应式布局支持手机访问
  • 国际化:中英文切换支持

八、总结

通过这个项目,你可以学到:

技能领域收获
Python后端Flask RESTful API设计、ORM操作、JWT认证
Vue前端Composition API、Pinia状态管理、ECharts可视化
数据处理Excel数据清洗、去重策略、单位转换
工程实践项目结构组织、前后端分离、部署运维

源码已整理完毕,如有需要可关注私信获取~

如果觉得有帮助,欢迎点赞收藏关注!有问题评论区交流~

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/15 1:25:05

SNN与PRC融合的sEMG手势识别技术解析

1. sEMG手势识别技术背景与挑战表面肌电信号&#xff08;sEMG&#xff09;手势识别技术通过采集皮肤表面微弱的肌肉电活动&#xff0c;解码人体运动意图&#xff0c;是人机交互领域的重要研究方向。这项技术的核心价值在于其非侵入性和自然交互特性——用户无需植入电极或穿戴复…

作者头像 李华
网站建设 2026/5/15 1:22:52

手把手教你搭建本地ChatGPT语音助手:从环境配置到功能扩展

1. 项目概述与核心价值最近在GitHub上看到一个挺有意思的项目&#xff0c;叫“chatGPT-Voice-Assistant”。光看名字&#xff0c;你大概就能猜到它的核心功能&#xff1a;一个能和你“对话”的ChatGPT语音助手。这玩意儿本质上是一个本地运行的桌面应用&#xff0c;它打通了你的…

作者头像 李华
网站建设 2026/5/15 1:21:24

RePKG终极指南:5个技巧解锁Wallpaper Engine壁纸资源自由

RePKG终极指南&#xff1a;5个技巧解锁Wallpaper Engine壁纸资源自由 【免费下载链接】repkg Wallpaper engine PKG extractor/TEX to image converter 项目地址: https://gitcode.com/gh_mirrors/re/repkg 你是否曾对Wallpaper Engine中那些精美的动态壁纸感到好奇&…

作者头像 李华
网站建设 2026/5/15 1:21:16

Windows平台APK安装终极指南:5分钟快速上手开源神器

Windows平台APK安装终极指南&#xff1a;5分钟快速上手开源神器 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 还在为Windows系统无法直接安装安卓应用而烦恼吗&#…

作者头像 李华