博主介绍:✌全网粉丝10W+,前互联网大厂软件研发、集结硕博英豪成立工作室。专注于计算机相关专业项目实战6年之久,选择我们就是选择放心、选择安心毕业✌
> 🍅想要获取完整文章或者源码,或者代做,拉到文章底部即可与我联系了。🍅

点击查看作者主页,了解更多项目!

🍅感兴趣的可以先收藏起来,点赞、关注不迷路,大家在毕设选题,项目以及论文编写等相关问题都可以给我留言咨询,希望帮助同学们顺利毕业 。🍅

1、毕业设计:2025年计算机专业毕业设计选题汇总(建议收藏)✅

2、最全计算机专业毕业设计选题大全(建议收藏)✅

1、项目介绍

技术栈:
Python语言、Django框架、vue框架、Echarts 可视化、MySQL 数据库、豆果美食网、html css js juery
基于django的美食菜谱数据分析可视化系统

摘 要

随着互联网技术的不断发展,传统美食菜谱行业面临着信息更新慢、用户体验差等问题。菜谱管理和展示通常依赖静态网页和纸质媒介,导致信息获取途径有限。计算机技术,数据可视化和智能推荐技术的进步,为行业数字化转型提供了新的契机,满足了现代用户对美食信息高效、直观获取的需求。
本系统采用Python语言开发,后端基于Django框架,前端使用Vue.js框架,并结合Echarts进行数据可视化,数据存储使用MySQL数据库。系统通过爬虫技术抓取豆果美食网的海量菜谱数据,进行管理和展示。该系统不仅具备传统的菜谱信息管理功能,还通过数据可视化展示菜谱热度、评分等趋势,帮助用户更直观地了解各类菜谱。系统的主要功能包括菜谱信息管理、数据可视化展示、菜谱搜索与筛选、用户评论与评分以及个性化推荐。数据可视化功能提升了用户的交互体验,个性化推荐根据用户偏好提供定制化菜谱,增强了系统的智能性。本系统通过高效的数据管理和智能分析,推动了美食行业的信息化和智能化转型,提升了用户体验。

关键词:美食菜谱,数据可视化,Django,Vue.js,Echarts,MySQL

2、项目界面

(1)美食菜品数据
在这里插入图片描述

(2)分类可视化前十

在这里插入图片描述

(3)类型可视化前十
在这里插入图片描述

(4)配料分布分析

在这里插入图片描述

(5)菜式分类

在这里插入图片描述

(6)所有配料可视化分析

在这里插入图片描述

(7)作者分布图
在这里插入图片描述

(8)作者分布词云图

在这里插入图片描述

(9)配料分析图

在这里插入图片描述

(10)后台数据管理

在这里插入图片描述

3、项目说明

基于Django的美食菜谱数据分析可视化系统是一个使用Python语言和Django框架开发的Web应用程序。它还使用了Vue框架和Echarts可视化工具来实现数据可视化。

该系统的主要功能是对豆果美食网的菜谱数据进行分析和可视化展示。用户可以通过系统的界面进行菜谱搜索、分类浏览等操作,系统会根据用户的需求从MySQL数据库中获取相应的数据。

系统的前端使用了HTML、CSS、JavaScript和JQuery等技术来实现页面的布局和交互效果。用户可以通过系统的界面进行菜谱搜索、分类浏览等操作。

系统的后端使用了Python语言和Django框架来处理用户的请求,并与MySQL数据库进行交互。系统会根据用户的需求从数据库中获取相应的数据,并使用Echarts可视化工具将数据以图表的形式展示出来。

通过该系统,用户可以方便地进行美食菜谱的数据分析和可视化展示,帮助用户更好地理解和利用菜谱数据。同时,该系统还提供了用户注册、登录、个人信息管理等功能,以及对菜谱的收藏、评论等操作,提升了用户的交互体验。

总 结
本研究开发并实现了一个基于Python的美食菜谱数据可视化分析系统。该系统采用先进的数据处理技术和直观的用户界面,提升用户的菜谱浏览体验,并为餐饮行业提供有价值的数据分析支持。系统的设计、实现与测试严格遵循工程与科研标准,功能完备且操作简便。
系统的后端采用Django框架,通过RESTful API与前端进行数据交互。前端基于Vue.js框架,结合HTML5、CSS3与JavaScript技术,呈现动态页面展示,用户可以流畅浏览和互动。数据的实时更新与存储依赖MySQL数据库,能够高效管理大量菜谱数据,并支持快速查询与分析。美食数据来自豆果美食网,通过Python中的BeautifulSoup与Selenium模块实现自动化数据抓取。所爬取的数据涵盖了菜谱的详细信息。在数据分析和可视化方面,系统通过柱状图和折线图展示了不同菜谱类型的分布,帮助用户直观了解各菜系的流行趋势。系统还通过饼图和柱状图展示了各类菜式所需配料的分布,揭示了不同菜系的配料特征。通过发布人配料分析功能,用户可以查看作者分布图和词云图,深入了解不同发布人使用的配料。收藏量和浏览量的可视化分析使用户能够迅速识别最受欢迎的菜谱,并根据不同地区和菜系提供个性化推荐。
本系统不仅提供了强大的数据分析功能,还通过可视化手段帮助用户更好地理解菜谱趋势,为餐饮企业提供数据支持,推动基于数据驱动的业务决策。系统架构设计考虑了扩展性和维护性,能够支持未来的功能拓展与系统优化。在测试阶段,系统经历了功能测试、性能测试和安全性测试,验证了其稳定性和高效性。所有功能模块均按预期工作,界面响应迅速,操作简便,符合项目的设计目标。
本研究表明,利用现代数据分析技术与可视化手段能够有效提升美食行业的运营效率,推动数据驱动决策的应用。未来,系统将进一步优化数据处理效率,并扩展更多功能,用户反馈机制、社交网络分析等,增强系统的互动性与个性化服务。

4、核心代码


import uuid
from collections import Counter

from django.http import HttpResponse, JsonResponse
from django.shortcuts import render

from django.views.decorators.csrf import csrf_exempt
from django.db.models import *
from app01 import models
import json
from django.core import serializers


# 登陆
def login(request):
    data = {}
    res = json.loads(request.body)
    password = res.get("password")
    name = res.get("name")
    print(name, password)
    use = models.User.objects.filter(name=name).filter(password=password).values()
    print(len(use))
    data["login"] = len(use)
    return JsonResponse(data=data, json_dumps_params={'ensure_ascii': False})


# 注册
def zc(request):
    data = {}
    res = json.loads(request.body)
    password = res.get("password")
    name = res.get("name")
    print(name, password)
    zc = 0
    user = models.User.objects.filter(name=name)
    if len(user) == 0:
        uid = models.User(id=uuid.uuid1(), name=name, password=password).save()
        user = models.User.objects.filter(name=name)
        print(user)
        zc = 1
    data["login"] = zc
    return JsonResponse(data=data, json_dumps_params={'ensure_ascii': False})


def home(request):
    data = {}
    res = json.loads(request.body)
    name = res.get("type")
    img = models.Menu.objects.filter(big_type=name).values("img")[0:5]
    items = models.Menu.objects.raw(
        'select id, count(type) ,type from menu where big_type = "' + str(name) + '" group by type')
    item = []
    for i in items:
        d = {"label": i.type}
        item.append(d)
    data["img"] = list(img)
    data["items"] = list(item)
    return JsonResponse(data=data, json_dumps_params={'ensure_ascii': False})


def info(request):
    res = json.loads(request.body)
    data = {}
    i = res.get("pageIndex")
    size = res.get("pageSize")
    name = res.get("name")
    big = res.get("value")
    num = res.get("num")
    ll = models.Menu.objects.raw("select id, count(big_type) value,big_type name from menu group by  q big_type")
    if num == '':
        li = models.Menu.objects.filter(name__contains=name).filter(big_type__contains=big).order_by(
            'type').values()[
             (i - 1) * size:i * size]
        total = models.Menu.objects.filter(name__contains=name).filter(big_type__contains=big).values(
            "id").count()
    else:
        li = models.Menu.objects.filter(name__contains=name).filter(big_type__contains=big).filter(num=num).order_by(
            'type').values()[
             (i - 1) * size:i * size]
        total = models.Menu.objects.filter(name__contains=name).filter(big_type__contains=big).filter(num=num).values(
            "id").count()
    item = []

    #(1) MySQL5.5版本用下面的代码
    # for i in ll:
    #     d = {"value": i.name, "label": i.name}
    #     item.append(d)
    #

    #(2) MySQL5.7以上版本用下面的代码
    for i in list(li):
        l = i['peiliao'].split(',')
        i['num'] = len(l)




    data["items"] = list(item)
    data["list"] = list(li)
    data["total"] = total
    return JsonResponse(data=data, json_dumps_params={'ensure_ascii': False})


def echarts(request):
    data = {}
    big = models.Menu.objects.raw(
        "select id, count(big_type) value,big_type name from menu group by big_type order by value desc limit 20")
    item = []
    for i in big:
        d = {"name": i.name, "value": i.value}
        item.append(d)
    data["big"] = list(item)
    type = models.Menu.objects.raw(
        "select id, count(type) value,type name from menu group by type order by value desc limit 50")
    item = []
    for i in type:
        d = {"name": i.name, "value": i.value}
        item.append(d)
    data["type"] = list(item)
    return JsonResponse(data=data, json_dumps_params={'ensure_ascii': False})


def echarts1(request):
    data = {}
    num = models.Menu.objects.raw(
        "select id, count(num) value,num name from menu group by num order by value desc limit 20")
    item = []
    for i in num:
        d = {"name": i.name, "value": i.value}
        item.append(d)
    data["num"] = list(item)
    type = models.Menu.objects.raw(
        "select id,count(num) value,num name from menu where big_type = '中国菜' group by num order by value desc limit 10")
    item = []
    for i in type:
        d = {"name": i.name, "value": i.value}
        item.append(d)
    data["china"] = list(item)
    wai = models.Menu.objects.raw(
        "select id,count(num) value,num name from menu where big_type = '外国菜' group by num order by value desc limit 10")
    item = []
    for i in wai:
        d = {"name": i.name, "value": i.value}
        item.append(d)
    data["wai"] = list(item)
    ge = models.Menu.objects.raw(
        "select id,count(num) value,num name from menu where big_type = '各地小吃' group by num order by value desc limit 10")
    item = []
    for i in ge:
        d = {"name": i.name, "value": i.value}
        item.append(d)
    data["ge"] = list(item)
    cs = models.Menu.objects.raw(
        "select id,count(num) value,num name from menu where big_type = '菜式' group by num order by value desc limit 10")
    item = []
    for i in cs:
        d = {"name": i.name, "value": i.value}
        item.append(d)
    data["cs"] = list(item)
    return JsonResponse(data=data, json_dumps_params={'ensure_ascii': False})

🍅✌感兴趣的可以先收藏起来,点赞关注不迷路,想学习更多项目可以查看主页,大家在毕设选题,项目代码以及论文编写等相关问题都可以给我留言咨询,希望可以帮助同学们顺利毕业!🍅✌

5、源码获取方式

🍅由于篇幅限制,获取完整文章或源码、代做项目的,拉到文章底部即可看到个人联系方式。🍅

点赞、收藏、关注,不迷路,下方查看👇🏻获取联系方式👇🏻

Logo

永洪科技,致力于打造全球领先的数据技术厂商,具备从数据应用方案咨询、BI、AIGC智能分析、数字孪生、数据资产、数据治理、数据实施的端到端大数据价值服务能力。

更多推荐