国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)

這篇具有很好參考價值的文章主要介紹了Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

作者主頁:編程指南針

作者簡介:Java領(lǐng)域優(yōu)質(zhì)創(chuàng)作者、CSDN博客專家 、掘金特邀作者、多年架構(gòu)師設(shè)計經(jīng)驗、騰訊課堂常駐講師

主要內(nèi)容:Java項目、簡歷模板、學(xué)習(xí)資料、面試題庫、技術(shù)互助

收藏點贊不迷路? 關(guān)注作者有好處

文末獲取源碼?

項目編號:BS-Python-006

一,環(huán)境介紹

語言環(huán)境:Python3.7

數(shù)據(jù)庫:Mysql: mysql5.7

開發(fā)工具:IDEA 或其它

開發(fā)技術(shù):Django框架,前端使用Layui+html

二,項目簡介

本項目基于Python語言開發(fā)實現(xiàn),使用了Django WEB框架開發(fā),前端使用Layui+HTML進(jìn)行頁面開發(fā),提供了登錄驗證碼和圖形報表統(tǒng)計,以及數(shù)據(jù)導(dǎo)入導(dǎo)出的基本功能。

系統(tǒng)的用戶角色可以靈活的自定義實現(xiàn),目前設(shè)定的有管理員、班主任和普通用戶等,可以根據(jù)需求自定義角色和權(quán)限,系統(tǒng)權(quán)限分為菜單級和按鈕級,控制的十分細(xì)致,完全根據(jù)需要來控制對某些數(shù)據(jù)的增刪改查操作,并根據(jù)需要給相應(yīng)的用戶授予相應(yīng)的權(quán)限。

系統(tǒng)的主要功能模塊包含:

用戶管理:完成對用戶信息的新增、查詢和刪除、導(dǎo)出等操作。

角色管理:完成對角色信息的新增、查詢和編輯、刪除、導(dǎo)出等操作。為角色授于不同的權(quán)限功能。

權(quán)限管理:完成對權(quán)限信息的新增、查詢和刪除、導(dǎo)出和啟用等操作。

日志管理:主要對用戶的操作日志進(jìn)行查看和刪除操作。

學(xué)校管理:完成對學(xué)校信息的新增、查詢和刪除操作。

年級管理:完成對年級信息的新增、查詢和刪除操作。

班級管理:完成對班級信息的新增、查詢和刪除操作。

課程管理:完成對課程信息的新增、查詢和刪除操作。

學(xué)生管理:完成對學(xué)生信息的新增、查詢和刪除操作,并可以進(jìn)行批量導(dǎo)入和導(dǎo)出。

成績錄入:為每個學(xué)生進(jìn)行成績錄入。

班級成績:查詢統(tǒng)計各學(xué)校各班級各學(xué)科的參考人數(shù)及各分?jǐn)?shù)段的人數(shù)。

學(xué)生成績:對所有學(xué)生的成績信息進(jìn)行管理和數(shù)據(jù)導(dǎo)入等操作。

數(shù)據(jù)統(tǒng)計:通過Echart圖形報表完成相關(guān)數(shù)據(jù)統(tǒng)計。

個人資料修改:完成個人資料和密碼的修改操作。

三,系統(tǒng)展示

用戶登錄:

Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)

后臺管理首頁:

Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)

用戶管理:

Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)

角色管理:

Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)

分配權(quán)限:

Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)

權(quán)限管理

Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)

日志管理

Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)

學(xué)校管理

Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)

年級管理

Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)

班級管理

Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)

課程管理

Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)

學(xué)生管理

Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)

成績錄入

Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)

班級成績統(tǒng)計

Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)

學(xué)生成績管理

Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)

四,核心代碼展示

# encoding:utf-8
import json
from io import BytesIO
from django.contrib.auth import logout
from django.contrib.auth.hashers import check_password, make_password
from django.http import JsonResponse, HttpResponse
from django.shortcuts import render, redirect

# Create your views here.
from common.API import res_josn_data
from common.API.auth import add_auth_session, login_required
from common.API.captcha import make_captcha
from common.API.code import check_code
from common.API.echarts import echarts_pie, json_response
from common.API.log import login_log
from login.models import Logo, Log
from sys_manage.models import User, Role, Power, RolePower
from student_score import models as m_model


def index(request):
    if request.method == 'GET':
        return redirect('/login')


def home(request):
    if request.method == 'GET':
        return render(request, 'login/home.html')


def login(request):
    if request.method == 'GET':
        return render(request, 'login/login.html')
    if request.method == 'POST':
        username = request.POST.get('username')
        password = request.POST.get('password')
        code = request.POST.get('captcha')

        if not username or not password or not code:
            return res_josn_data.fail_api(msg="用戶名或密碼沒有輸入")
        s_code = request.session.get("code", None)
        print('驗證碼:', code, s_code)
        user_ip = request.META.get('REMOTE_ADDR')
        print(user_ip)

        request.session["code"] = None

        if not all([code, s_code]):
            # login_log(request, uid=username, is_access=False, desc='驗證碼錯誤,請刷新驗證碼')
            return res_josn_data.fail_api(msg="驗證碼錯誤,請刷新驗證碼!")

        if code != s_code:
            login_log(request, uid=username, is_access=False, desc='驗證碼錯誤')
            return res_josn_data.fail_api(msg="驗證碼錯誤")

        user = User.objects.filter(id_number=username).first()

        if user is None:
            login_log(request, uid=username, is_access=False, desc='用戶不存在')
            return res_josn_data.fail_api(msg="用戶不存在!")

        if user.user_status == 0:
            login_log(request, uid=user.id_number, is_access=False, desc='用戶被禁用')
            return res_josn_data.fail_api(msg="用戶被禁用!")

        if username == user.id_number and check_password(password, user.id_password):
            # 設(shè)置session過期時間
            request.session.set_expiry(60 * 60 * 2)
            # 登錄
            request.session["user_id"] = user.id_number
            request.session["user_name"] = user.user_name
            request.session["role_id"] = user.role_id
            request.session["role_des"] = user.role_des
            request.session["id"] = user.id
            # 學(xué)校名稱
            request.session["department"] = user.department

            # 年級
            request.session["position"] = user.position
            # 科目
            request.session["email"] = user.email
            # 記錄登錄日志
            login_log(request, uid=user.id_number, is_access=True, desc='登錄成功')
            # 存入權(quán)限
            add_auth_session(request)

            return res_josn_data.success_api(msg="登錄成功")

        else:
            login_log(request, uid=user.id_number, is_access=False, desc='密碼錯誤')
            return res_josn_data.fail_api(msg="密碼錯誤")
def image_code(request):
    """ 生成圖片驗證碼 """

    # 調(diào)用pillow函數(shù),生成圖片
    img, code_string = check_code()

    # 寫入到自己的session中(以便于后續(xù)獲取驗證碼再進(jìn)行校驗)
    request.session['image_code'] = code_string
    # 給Session設(shè)置60s超時
    request.session.set_expiry(60)

    stream = BytesIO()
    img.save(stream, 'png')
    return HttpResponse(stream.getvalue())


def get_captcha(request):
    return make_captcha(request)


def login_in(request):
    user_id = request.session.get('user_id')
    if user_id:
        return render(request, "login/index.html", {'user_id': user_id})


def login_out(request):
    user_id = request.session.get('user_id')
    login_log(request, uid=user_id, is_access=True, desc='退出登錄')
    logout(request)
    return redirect('/login')


@login_required
def web_menu(request):
    home_info = Logo.objects.filter(type='0').first()
    logo_info = Logo.objects.filter(type='1').first()
    title_info = Logo.objects.filter(type='2').first()
    menu_info = Power.objects.filter(type=0).order_by('sort')  # 目錄
    # 查詢權(quán)限ID
    menu_id = RolePower.objects.values_list('power_id').filter(role_id=request.session.get('role_id'))
    permission_id = [i[0] for i in menu_id]
    print(f'當(dāng)前用戶權(quán)限ID:{permission_id}')

    menu_data = {
        "homeInfo": {
            "title": f"{home_info.name}",
            "href": f"{home_info.url}"
        },
        "logoInfo": {
            "title": f"{logo_info.name}",
            "image": f"{logo_info.icon}",
            "href": f"{logo_info.url}"
        },
        "menuInfo": [
            {
                "title": f"{title_info.name}",
                "icon": f"{title_info.icon}",
                "href": f"{title_info.url}",
                "target": "_self",
                "child": []
            }
        ]
    }
    for item in menu_info:
        if item.id in permission_id:
            menu_data["menuInfo"][0]["child"].append({
                "title": f"{item.name}",
                "icon": f"{item.icon}",
                "href": f"{item.code}",
                "target": "_self",
                "child": []
            })
            # 查詢子菜單
            sub_menu_info = Power.objects.filter(parent_id=item.id).order_by('sort')
            for sub_item in sub_menu_info:
                if sub_item.id in permission_id:
                    menu_data["menuInfo"][0]["child"][-1]["child"].append({
                        "title": f"{sub_item.name}",
                        "icon": f"{sub_item.icon}",
                        "href": f"{sub_item.code}",
                        "target": "_self"
                    })

    return JsonResponse(menu_data, safe=False)


@login_required
def echarts(request):
    if request.method == 'POST':
        n_type = ['用戶', '角色', '權(quán)限', '日志']
        user_count = User.objects.count()
        role_count = Role.objects.count()
        role_power_count = RolePower.objects.count()
        log_count = Log.objects.count()
        data_list = [user_count, role_count, role_power_count, log_count]
        title = '1.數(shù)量統(tǒng)計'
        c = echarts_pie(n_type, data_list, title)
        return json_response(json.loads(c))


@login_required
def user_setting(request):
    if request.method == 'GET':
        return render(request, "login/user_setting.html")
    if request.method == "POST":
        post_data = request.POST
        print(post_data)
        field_user_id = post_data['userID']
        field_name = post_data['userName']
        field_dep = post_data['department']
        field_pos = post_data['position']
        field_email = post_data['email']
        update_dict = {
            'user_name': field_name,
            'department': field_dep,
            'position': field_pos,
            'email': field_email
        }
        User.objects.filter(id_number=field_user_id).update(**update_dict)
        return res_josn_data.success_api(msg=f'用戶:{field_user_id} 更新成功')


@login_required
def user_info_query(request):
    data_list = []
    post_data = request.POST
    print('AJAX數(shù)據(jù):', post_data)
    login_id = post_data['login_id'].strip()
    user_info = User.objects.filter(id_number=login_id).first()
    role_info = Role.objects.filter(role_value=user_info.role_id).first()

    return res_josn_data.user_setting_api(login_id, user_info.user_name, user_info.department, user_info.position,
                                          role_info.name, user_info.email, data_list)


@login_required
def user_password(request):
    if request.method == 'GET':
        return render(request, "login/user_password.html")
    if request.method == "POST":
        post_data = request.POST
        print(post_data)
        login_id = post_data['login_id'].strip()
        old_password = post_data['Param[old_password]']
        new_password = post_data['Param[new_password]']
        again_password = post_data['Param[again_password]']
        user_obj = User.objects.filter(id_number=login_id).first()
        if not user_obj:
            return res_josn_data.fail_api(msg="用戶不存在!")
        if not check_password(old_password, user_obj.id_password):
            return res_josn_data.fail_api(msg="舊密碼錯誤!")
        if new_password != again_password:
            return res_josn_data.fail_api(msg="兩次密碼不一致!")
        User.objects.filter(id_number=login_id).update(**{'id_password': make_password(new_password)})
        return res_josn_data.success_api(msg="修改成功!")


# def page_not_found(request, exception):
#     return render(request, "errors/404.html", exception)
#
#
# def page_error(request):
#     return render(request, "errors/500.html")
# encoding:utf-8
import json

from django.contrib.auth.hashers import make_password
from django.core.paginator import Paginator
from django.shortcuts import render
from student_score import models as m_model
# Create your views here.

from common.API import res_josn_data
from common.API.auth import login_required, authorize
from sys_manage.models import User, Role


@login_required
def user_manage(request):
    return render(request, 'sys_manage/user_manage/user_main.html')


@login_required
def user_query(request):
    data_list = []
    page = request.POST.get('page', 1)
    limit = request.POST.get('limit', 10)
    post_data_str = request.POST.get('Params', None)

    if post_data_str is None:
        user_obj = User.objects.all().order_by('id')
        # return res_josn_data.table_api(data=data_list, count=0)
    else:
        post_data = json.loads(post_data_str)
        id_number = post_data['idNumber']
        user_name = post_data['userName']
        user_dep = post_data['dep']
        user_pos = post_data['position']
        user_status = post_data['status']
        user_role = post_data['role']

        filters = {}  # 查詢參數(shù)構(gòu)造
        # model或數(shù)據(jù)庫對應(yīng)字段
        orm_field = ['__gt', '__gte', '__lt', '__lte', '__exact', '__iexact', '__contains', '__icontains',
                     '__startswith', '__istartswith', '__endswith', '__iendswith', '__range', '__isnull', '__in']
        filed_dict = {0: 'id_number', 1: 'user_name', 2: 'department', 3: 'position', 4: 'user_status', 5: 'role_id'}
        param_list = [id_number, user_name, user_dep, user_pos, user_status, user_role]

        for i in range(len(param_list)):
            if param_list[i] not in (None, ''):
                db_field = filed_dict[i] + orm_field[7]
                filters[db_field] = param_list[i]

        print('filters:', filters)

        user_obj = User.objects.filter(**filters).order_by('id')
    page_data = Paginator(user_obj, limit).page(page)

    # 序號
    count = (int(page) - 1) * int(limit)

    for item in page_data:
        count += 1
        item_data = {
            "id": count,
            "fieldID": item.id,
            "userID": item.id_number,
            "name": item.user_name,
            "department": item.department,
            "position": item.position,
            "email": item.email,
            "status": item.user_status,
            "role": item.role_des,
        }
        data_list.append(item_data)

    return res_josn_data.table_api(count=len(user_obj), data=data_list)


@authorize(power='user:add', log=True)
def user_add(request):
    if request.method == 'GET':
        return render(request, 'sys_manage/user_manage/user_add.html')
    if request.method == 'POST':
        post_data = request.POST
        print(request.POST)
        user_id = post_data['userID']
        user_password = post_data['password']
        user_name = post_data['userName']
        user_dep = post_data['department']
        user_position = post_data['position']
        user_email = post_data['email']
        user_enable = post_data['enable']
        role_value = post_data['role']

        user_password_sha256 = make_password(user_password, salt=None, hasher='default')
        role_obj = Role.objects.filter(role_value=role_value).first()

        new_obj = User(
            id_number=user_id,
            id_password=user_password_sha256,
            user_name=user_name,
            department=user_dep,
            position=user_position,
            role_id=role_value,
            role_des=role_obj.name,
            user_status=user_enable,
            email=user_email,
        )
        new_obj.save()
        return res_josn_data.success_api(msg=f'用戶:{user_name} 添加成功')


@login_required
def user_role_query(request):
    if request.method == 'POST':
        data_list = []
        role_data = Role.objects.all()
        for item in role_data:
            item_data = {
                "roleID": item.role_value,
                "roleName": item.name
            }
            data_list.append(item_data)
        print(data_list)
        return res_josn_data.table_api(data=data_list, count=len(role_data))
def school_query(request):
    if request.method == 'POST':
        data_list = []

        school_data = m_model.College.objects.all()
        for item in school_data:
            item_data = {
                "schoolID": item.id,
                "schoolName": item.name
            }
            data_list.append(item_data)
        return res_josn_data.table_api(data=data_list, count=len(school_data))

@authorize(power='user:delete', log=True)
def user_delete(request):
    if request.method == 'POST':
        post_data = request.POST
        print('AJAX數(shù)據(jù):', post_data)
        db_id = post_data['fieldID']
        user_name = post_data['name']
        User.objects.filter(id=db_id).delete()
        return res_josn_data.success_api(f'用戶:{user_name} 刪除成功')
    else:
        return res_josn_data.fail_api(msg='請求權(quán)限不夠!')


@authorize(power='user:delete', log=True)
def user_multi_delete(request):
    if request.method == 'POST':
        user_list = []
        post_data_str = request.POST.get('Params', None)
        post_data = json.loads(post_data_str)
        for item in post_data:
            db_id = item['fieldID']
            user_name = item['name']
            User.objects.filter(id=db_id).delete()
            user_list.append(user_name)
        return res_josn_data.success_api(f'用戶:{user_list} 刪除成功')


@login_required
def user_cell_edit(request):
    # 前端字段和數(shù)據(jù)庫字段對應(yīng)dict
    filed_dict = {
        'userID': 'id_number',
        'name': 'user_name',
        'department': 'department',
        'position': 'position',
        'email': 'email',
    }
    if request.method == 'POST':
        post_data = request.POST
        print('AJAX數(shù)據(jù):', post_data)
        field_name = post_data['field']
        field_value = post_data['value']
        field_id = post_data['dbID']
        User.objects.filter(id=field_id).update(**{filed_dict[field_name]: field_value})
        return res_josn_data.success_api(f'更新成功')


@login_required
def user_role_edit(request):
    if request.method == 'GET':
        return render(request, 'sys_manage/user_manage/user_role_edit.html')
    if request.method == 'POST':
        post_data = request.POST
        print(post_data)
        user_id = post_data['userID']
        role_id = post_data['role']
        role_obj = Role.objects.filter(role_value=role_id).first()
        update_dict = {
            'role_id': role_id,
            'role_des': role_obj.name
        }
        User.objects.filter(id_number=user_id).update(**update_dict)
        return res_josn_data.success_api(msg=f'{user_id} 角色更新成功')


@authorize(power='user:enable', log=True)
def user_enable(request):
    if request.method == 'POST':
        post_data = request.POST
        print('AJAX數(shù)據(jù):', post_data)
        field_id = post_data['userID']
        enable_value = post_data['enableValue']  # 0禁用 1啟用
        enable_dict = {'enable': 1, 'disable': 0}
        enable_dict_cn = {'enable': '啟用', 'disable': '禁用'}
        role_obj = User.objects.filter(id=field_id)
        role_obj.update(**{'user_status': enable_dict[enable_value]})
        return res_josn_data.success_api(msg=f'{role_obj[0].user_name} {enable_dict_cn[enable_value]}成功')

五,項目總結(jié)

本次基于Python開發(fā)實現(xiàn)的學(xué)生成績管理系統(tǒng),也可作為學(xué)生管理系統(tǒng)使用,題目根據(jù)需要可以更改,功能實現(xiàn)較為完整,界面設(shè)計美觀大方,適合作為畢業(yè)設(shè)計和課程設(shè)計使用。文章來源地址http://www.zghlxwxcb.cn/news/detail-496019.html

到了這里,關(guān)于Python畢業(yè)設(shè)計|課程設(shè)計|基于Python+Django實現(xiàn)的學(xué)生成績管理系統(tǒng)的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進(jìn)行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包