# Hadoop外卖点餐数据分析可视化系统 **Repository Path**: guangduan/Hadoop-takeout-order-data-analysis-and-visualization-system ## Basic Information - **Project Name**: Hadoop外卖点餐数据分析可视化系统 - **Description**: 基于大数据的校园外卖点餐系统设计与实现采用Spring Boot、Vue.js、MySQL、Hadoop,hdfs,Scrapy爬虫(美团),数据分析大屏看板、Echarts可视化等技术,构建了一个功能全面的Web应用。 - **Primary Language**: Java - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2025-09-20 - **Last Updated**: 2025-09-25 ## Categories & Tags **Categories**: Uncategorized **Tags**: Springboot-vue-mysql, hadoop-hdfs, Scrapy爬虫, 数据分析, Echarts可视化 ## README ## 基于大数据的校园外卖点餐数据分析可视化系统 ## 基于Hadoop的外卖点餐数据分析可视化系统** ## 前言介绍 本文基于大数据的校园点餐系统设计与实现采用Spring Boot、Vue.js、MySQL、Hadoop等技术,构建了一个功能全面的Web应用。该系统实现了用户注册与登录、用户信息管理、外卖信息和公告资讯等管理,外卖点餐数据分析大屏展示等功能模块,为用户了解外平台的点餐数据和未来外卖市场的前景提供了肉眼可见的数据分析展示。管理员可以通过系统进行各种信息管理和外卖数据的爬取等,确保推荐内容的时效性和准确性。 系统通过整合前后端技术,提供了高效的数据处理和用户体验。Hadoop集群负责存储和处理大规模外卖信息数据。系统的模块化设计使得各功能相互独立又紧密协作,提升了系统的可扩展性和维护性。用户能够方便地浏览评分高和销量高的外卖,管理员则可以灵活地管理用户和外卖信息以及对数据进行数据分析统计,准确洞悉外卖平台餐品的评分和销量以及用户喜爱程度,为后续提升外卖平台的运营提供了便捷的途径。 ## 01开发环境 1.1 Java 技术 1.2 Spring Boot 框架 1.3 Hadoop,hdfs 1.4 Scrapy爬虫 1.5 MySQL数据库 1.6 B/S 结构 1.7 Vue.js 技术 1.8 基于用户收藏的协同算法 ## 02系统功能模块 亮点(爬虫【美团】、基于用户收藏的协同算法、数据分析看板、Echarts可视化) 1、数据管理:爬虫信息列表展示。 2、数据存储:mysql数据库。 3、可视化分析:各种数据分析统计后图表大屏展示 4、数据分析:根据hadoop大数据技术进行数据分析 ## 03图片展示 ![输入图片说明](07.png) ![输入图片说明](08.png) ![输入图片说明](09.png) ![输入图片说明](010.png) ![输入图片说明](01.png) ![输入图片说明](02.png) ![输入图片说明](03.png) ![输入图片说明](04.png) ![输入图片说明](05.png) ## 04部分代码展示 ```java /** * 交流学习vx18484646674 * 协同算法(按用户收藏行为推荐) */ @RequestMapping("/autoSort2") public R autoSort2(@RequestParam Map params,NewsEntity news, HttpServletRequest request){ String userId = request.getSession().getAttribute("userId").toString(); String inteltypeColumn = "typename"; List storeups = storeupService.selectList(new EntityWrapper().eq("type", 1).eq("userid", userId).eq("tablename", "news").orderBy("addtime", false)); List inteltypes = new ArrayList(); Integer limit = params.get("limit")==null?10:Integer.parseInt(params.get("limit").toString()); List newsList = new ArrayList(); //去重 if(storeups!=null && storeups.size()>0) { List typeList = new ArrayList(); for(StoreupEntity s : storeups) { if(typeList.contains(s.getInteltype())) continue; typeList.add(s.getInteltype()); newsList.addAll(newsService.selectList(new EntityWrapper().eq(inteltypeColumn, s.getInteltype()))); } EntityWrapper ew = new EntityWrapper(); params.put("sort", "id"); params.put("order", "desc"); PageUtils page = newsService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, news), params), params)); List pageList = (List)page.getList(); if(newsList.size()