毕业设计:基于python商品比价系统+requests爬虫+可视化+Django框架 大数据项目(附源码)✅

184 篇文章 45 订阅
178 篇文章 9 订阅

毕业设计:2023-2024年计算机专业毕业设计选题汇总(建议收藏)

毕业设计:2023-2024年最新最全计算机专业毕设选题推荐汇总

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

1、项目介绍

技术栈:
Python语言、MySQL数据库、Django框架、requests爬虫技术、HTML
系统的优点包括:

  • 相对简单:使用Django和requests可以快速搭建起一个功能完善的爬虫系统。
  • 高效稳定:Django框架提供了高效的开发工具和规范,requests库提供了稳定可靠的HTTP请求功能。
  • 可拓展性强:Django框架支持模块化开发,可以方便地添加新的功能模块或扩展已有的功能。

总之,基于Django和requests的京东商品爬虫系统可以帮助用户方便地获取京东商品信息,并提供了用户友好的界面和功能。

2、项目界面

(1)商品比价界面

在这里插入图片描述

(2)商品推荐

在这里插入图片描述

(3)系统主页

在这里插入图片描述

(4)注册登录界面

在这里插入图片描述

(5)后台数据管理

在这里插入图片描述

3、项目说明

Django和requests是两个常用的Python库,可以用于构建爬虫系统和发送HTTP请求。下面是一个基于Django和requests的京东商品爬虫系统的介绍:

  1. Django:Django是一个开发高效、功能强大的Web应用程序的Python框架。它提供了一套完整的开发工具和规范,使开发者能够快速构建可拓展的Web应用程序。

  2. requests:requests是一个简洁而又功能强大的HTTP库,可以发送各种类型的HTTP请求。它提供了简单易用的API,使得发送HTTP请求变得非常方便。

  3. 京东商品爬虫系统:这个系统可以用于爬取京东网站上的商品信息。通过发送HTTP请求获取商品页面,然后使用爬虫技术从页面中提取所需的商品信息,最后将信息保存到数据库中。

系统的主要功能包括:

  • 用户登录和注册:用户可以通过系统进行登录和注册,以获得更好的爬取体验。
  • 商品搜索和展示:用户可以输入关键字进行商品搜索,并展示搜索结果。搜索结果包括商品名称、价格、销量等信息。
  • 数据爬取和存储:系统会使用requests发送HTTP请求获取商品页面,并使用爬虫技术从页面中提取所需的商品信息。提取的信息会被保存到数据库中,以备后续使用。
  • 数据展示和导出:用户可以查看已爬取的商品信息,并可以选择将信息导出为Excel或CSV格式。

系统的优点包括:

  • 相对简单:使用Django和requests可以快速搭建起一个功能完善的爬虫系统。
  • 高效稳定:Django框架提供了高效的开发工具和规范,requests库提供了稳定可靠的HTTP请求功能。
  • 可拓展性强:Django框架支持模块化开发,可以方便地添加新的功能模块或扩展已有的功能。

总之,基于Django和requests的京东商品爬虫系统可以帮助用户方便地获取京东商品信息,并提供了用户友好的界面和功能。

4、核心代码


from django.shortcuts import render, redirect
from .models import UserProfile
from django.contrib.auth.decorators import login_required
from django.contrib.auth import logout, login, authenticate
from .forms import LoginForm
# Create your views here.


def do_register(request):
    try:
        msg = ""
        if request.method == "GET":
            return render(request, "register.html", locals())
        if request.method == "POST":
            user = request.user
            datas = request.POST
            username = request.POST.get("username")
            mobile = request.POST.get("mobile")
            email= request.POST.get("email")
            password = request.POST.get("password")
            password2 = request.POST.get("password2")

            if len(username) < 6 or len(password) < 6 or len(password2) < 6:
                msg="账号密码必须大于6位"
                return render(request, "register.html", locals())
            if len(username) < 6 or len(password) < 6 or len(password2) < 6:
                msg="两次输入的密码不一致"
                return render(request, "register.html", locals())
            if mobile == "" or mobile == None or len(mobile) != 11:
                msg = "手机号不能为空,必须11位且格式正确"
                return render(request, "register.html", locals())
            only = UserProfile.objects.filter(username=username)
            if len(only) > 0:
                msg = "用户名已经存在"
                return render(request, "register.html", locals())
            new_user = UserProfile()
            new_user.username = username
            new_user.mobile = mobile
            new_user.email = email
            new_user.set_password(password)
            new_user.mpassword = password
            new_user.save()
            return redirect("accounts:login")
        else:
            return render(request, "register.html", locals())
    except Exception as e:
        print(e)
        msg = "添加失败系统错误"
        return render(request, "register.html", locals())


def user_login(request):
    try:
        if request.user.is_authenticated:
            return redirect("/")
        if request.method == 'POST':
            login_form = LoginForm(request.POST)
            if login_form.is_valid():
                username = login_form.cleaned_data["username"]
                password = login_form.cleaned_data["password"]
                user = authenticate(username=username,password=password)
                if user is not None:
                    # user.backend = 'django.contrib.auth.backends.ModelBackend' # 指定默认的登录验证方式

                    login(request, user)
                else:
                    errorinfo = "账号或密码不正确"
                    return render(request, 'login.html', {'login_form': login_form, "errorinfo":errorinfo})
                return redirect("/")
            else:
                errorinfo = "账号或密码不正确或格式错误"
                return render(request, 'login.html', {'login_form': login_form, "errorinfo":errorinfo})
        else:
            login_form = LoginForm()
            return render(request, 'login.html', {'login_form': login_form})
    except Exception as e:
        login_form = LoginForm()
        print(e)
        errorinfo = "系统错误"
        return render(request, 'login.html', {'login_form': login_form, "errorinfo":errorinfo})

@login_required
def user_logout(request):
    try:
        logout(request)
        return redirect('accounts:login')
    except Exception as e:
        print(e)
    return render(request, "error.html", {"msg":"退出错误"})


@login_required
def my_info(request):
    try:
        user = request.user
        if request.method == "GET":
            return render(request, "my_info.html", locals())
        if request.method == "POST":
            username = request.POST.get("username", "")
            mobile = request.POST.get("mobile", "")
            email = request.POST.get("email", "")
            print(username)
            print(mobile)
            print(email)
            if username == "" or username == None or len(username) < 6:
                msg = "用户名不能为空,必须大于6位"
                return render(request, "my_info.html", locals())
            if mobile == "" or mobile == None or len(mobile) != 11:
                msg = "手机号不能为空,必须11位且格式正确"
                return render(request, "my_info.html", locals())

            user.username = username
            user.mobile = mobile
            user.email = email
            user.save()
            msg = "修改成功"
            return render(request, "my_info.html", locals())
    except Exception as e:
        print(e)
        msg = "系统错误"
        return render(request, "my_info.html", locals())


@login_required
def modify(request):
    try:
        user = request.user
        if request.method == 'POST':
            oldpassword = request.POST.get("oldpassword")
            newpassword = request.POST.get("newpassword")
            conpassword = request.POST.get("conpassword")
            print(user.mpassword)
            print(oldpassword)
            if user.mpassword != oldpassword:
                errorinfo = "旧密码错误"
                return render(request, 'modify.html',  locals())
            if newpassword != conpassword:
                errorinfo = "新旧密码不一致"
                return render(request, 'modify.html',  locals())
            if len(newpassword) < 6:
                errorinfo = "密码大于6位"
                return render(request, 'modify.html', locals())
            user.mpassword = newpassword
            user.set_password(newpassword)
            user.save()
            logout(request)
            return redirect("/accounts/login")
        else:
            return render(request, 'modify.html', locals())
    except Exception as e:
        print(e)
        errorinfo = "系统错误"
        return render(request, 'modify.html',  locals())



5、源码获取方式

🍅由于篇幅限制,获取完整文章或源码、代做项目的,查看我的【用户名】、【专栏名称】、【顶部选题链接】就可以找到我啦🍅

感兴趣的可以先收藏起来,点赞、关注不迷路,下方查看👇🏻获取联系方式👇🏻

  • 23
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
接口自动化测试框架是基于Python语言开发的,主要使用了以下几个工具和库:requests、yami、pytest、allure和logging。 首先,requestsPython中一个常用的HTTP库,在接口测试中用于发送HTTP请求,并获取响应结果。它提供了简洁的API,使得发送各种类型的请求变得非常方便。 其次,yami是一个用于解析接口返回数据的库。它可以帮助我们从HTTP响应中提取所需的数据,并进行断言判断,比如验证返回的状态码、响应内容等。 然后,pytest是一个Python的测试框架,它具有很强大的测试用例管理和执行能力。我们可以使用pytest来编写接口测试用例,并结合fixture功能对测试环境进行初始化和清理工作。 allure是一个用于生成测试报告的工具。它可以将测试结果以可视化的方式展示,同时具备丰富的报告元素,比如用例执行状态、失败原因等。这样可以方便查看测试结果,快速定位问题。 最后,logging是Python内置的日志记录工具,在接口自动化测试中,我们可以使用logging来记录一些重要的操作或错误信息,帮助我们进行调试和问题追踪。 综上所述,以上工具和库是常用于搭建接口自动化测试框架的重要组成部分。通过它们的结合使用,可以辅助我们完成接口测试的各项工作,包括发送请求、解析响应、断言判断、测试用例管理、生成测试报告等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值