做的响应式网站用什么测试/seo 的原理和作用

做的响应式网站用什么测试,seo 的原理和作用,dw软件网站建设教程,wordpress中文标签件####################################################总的urls.py from django.contrib import admin from django.urls import path,include, re_path from django.views.static import serve from django.conf import settings from drf_yasg import openapi from drf_yas…

####################################################总的urls.py

from django.contrib import admin
from django.urls import path,include, re_path
from django.views.static import serve
from django.conf import settings
from drf_yasg import openapi
from drf_yasg.views import get_schema_view
from rest_framework import permissions
from django.views.generic.base import RedirectView
from rest_framework_simplejwt.views import (
    TokenRefreshView,
)

from mysystem.views.login import LoginView,CaptchaView
from utils.swagger import CustomOpenAPISchemaGenerator

#前端接口view
from apps.logins.views import UsernamePassWordLoginView,APPMobilePasswordLoginView,SendSmsCodeView,APPMobileSMSLoginView,ForgetPasswdResetView,RegisterView
from apps.lyusers.views import SetUserNicknameView,ChangeAvatarView,uploadImagesView,DestroyUserView
from apps.lymessages.views import UserMessagesView,UserMessagesNoticeView,GetUnreadMessageNumView
from apps.platformsettings.views import *


#媒体文件流式响应
from utils.streamingmedia_response import streamingmedia_serve
#部署vue
from django.views.generic import TemplateView
#是否允许前端接口访问
from utils.middleware import OperateAllowFrontendView

schema_view = get_schema_view(
    openapi.Info(
        title="django-vue-lyadmin API",
        default_version='v1',
        # description="Test description",
        # terms_of_service="https://www.google.com/policies/terms/",
        # contact=openapi.Contact(email="contact@snippets.local"),
        # license=openapi.License(name="BSD License"),
    ),
    # public 如果为False,则只包含当前用户可以访问的端点。True返回全部
    public=True,
    permission_classes=(permissions.AllowAny,),# 可以允许任何人查看该接口
    # permission_classes=(permissions.IsAuthenticated) # 只允许通过认证的查看该接口
    generator_class=CustomOpenAPISchemaGenerator,
)

urlpatterns = [
    path('static/<path:path>', serve, {'document_root': settings.STATIC_ROOT},),  # 处理静态文件
    # path('media/<path:path>', serve, {'document_root': settings.MEDIA_ROOT},),  # 处理媒体文件
    path('media/<path:path>', streamingmedia_serve, {'document_root': settings.MEDIA_ROOT}, ),  # 处理媒体文件

    #管理后台的标准接口
    path('api/system/', include('mysystem.urls')),
    path('api/monitor/', include('lymonitor.urls')),
    path('api/terminal/', include('lywebsocket.urls')),
    path('api/token/', LoginView.as_view(), name='token_obtain_pair'),
    path('api/token/refresh/', TokenRefreshView.as_view(), name='token_refresh'),
    path('api/captcha/', CaptchaView.as_view()),

    #管理后台其他自定义接口
    path('api/platformsettings/', include('apps.platformsettings.urls')),
    path('api/messages/', include('apps.lymessages.urls')),
    path('api/users/', include('apps.lyusers.urls')),
    path('api/crontab/', include('apps.lycrontab.urls')),
    path('api/wholeMachine/', include('apps.wholeMachine.urls')),


    #获取平台信息
    path('api/getsysconfig/', GetSystemConfigSettingsView.as_view(), name='前端用户获取平台其他设置'),
    path('api/getothersettings/', GetOtherManageDetailView.as_view(), name='前端用户获取平台其他设置'),
    path('api/getrotationimgs/', GetLunboManageListView.as_view(), name='前端用户获取平台轮播图设置'),


    #是否允许前端接口访问(临时操作,重启后无效)
    path('api/super/operate/', OperateAllowFrontendView.as_view(), name='超级管理员动态操作是否允许前端api接口访问'),

    #集成部署后端管理页面

    path('favicon.ico',RedirectView.as_view(url=r'static/favicon.ico')),
    path('', TemplateView.as_view(template_name="index.html"),name='后台管理默认页面'),
]

####################################################models.py

from django.db import models
from utils.models import CoreModel
from application import settings

# ================================================= #
# ************** 服务器分类 model  ************** #
# ================================================= #


class ServersUsage(CoreModel):
    """整机用途"""
    objects = None
    name = models.CharField(max_length=255, unique=True, verbose_name='名称')
    desc = models.CharField( max_length=255,null=True, blank=True,verbose_name='描述')
    sort = models.PositiveSmallIntegerField(default=0, verbose_name="排序", help_text="显示顺序")
    status = models.BooleanField(default=True, verbose_name="整机用途状态", help_text="整机用途状态")
    is_delete = models.BooleanField(default=False, verbose_name="是否逻辑删除", help_text="是否逻辑删除")
    class Meta:
        db_table = 'tb_servers_usage'
        verbose_name = '整机用途'
        verbose_name_plural = verbose_name
    def __str__(self):
        return self.name


class ServersModel(CoreModel):
    """整机机型"""
    objects = None
    name = models.CharField( max_length=255,unique=True, verbose_name='名称')
    area= models.CharField(max_length=255, null=True, verbose_name='设备领域')
    desc = models.CharField( max_length=255,null=True, blank=True,verbose_name='描述')
    sort = models.PositiveSmallIntegerField(default=0, verbose_name="排序", help_text="显示顺序")
    status = models.BooleanField(default=True, verbose_name="整机机型状态", help_text="整机机型状态")
    is_delete = models.BooleanField(default=False, verbose_name="是否逻辑删除", help_text="是否逻辑删除")

    class Meta:
        db_table = 'tb_servers_model'
        verbose_name = '整机机型'
        verbose_name_plural = verbose_name

    def __str__(self):
        return self.name

# # ================================================= #
# # ************** 跳板机信息 ************** #
# # ================================================= ##
class JumpServers(CoreModel):
    """跳板机信息"""
    jumpip = models.CharField(max_length=255, verbose_name="跳板机IP")
    jumpuser = models.CharField(max_length=255, verbose_name="跳板机user")
    jumppassword= models.CharField(max_length=255,verbose_name="跳板机password")


# ================================================= #
# ************** 整机信息 ************** #
# ================================================= #

class ServersInfo(CoreModel):
    """整机信息"""
    objects = None
    serverFrom  = models.CharField(max_length=255,blank=True, null=True, verbose_name="信息来源")  #
    serverCode  = models.CharField(max_length=255,blank=False, null=False, unique=True,verbose_name="设备编号")  #
    location = models.CharField(max_length=255, blank=False, null=False,  verbose_name="设备位置")
    hardware = models.CharField(max_length=255, blank=True, null=True, verbose_name="硬件配置")
    serversModel = models.ForeignKey(ServersModel, on_delete=models.PROTECT,blank=False, null=False,verbose_name='设备型号')
    serversUsage = models.ForeignKey(ServersUsage, on_delete=models.PROTECT, blank=False, null=False,verbose_name='设备用途')
    status = models.BooleanField(default=True, verbose_name="设备状态", help_text="设备状态")
    bmcIP = models.CharField(max_length=255, verbose_name="BMC地址")
    bmcUser = models.CharField(max_length=255, verbose_name="bmcuser",blank=True)
    bmcPassword= models.CharField(max_length=255, verbose_name="bmcpassword",blank=True)
    hostIP = models.CharField(max_length=255, verbose_name="host地址",blank=True)
    hostUser = models.CharField(max_length=255, verbose_name="hostUser", blank=True)
    hostPassword = models.CharField(max_length=255, verbose_name="hostPassword", blank=True)
    serialIP = models.CharField(max_length=255, verbose_name="串口地址", blank=True,null=True)
    serialPort= models.CharField(max_length=255, verbose_name="串口端口", blank=True,null=True)
    serialUser = models.CharField(max_length=255, verbose_name="串口User",  blank=True,null=True)
    serialPassword = models.CharField(max_length=255, verbose_name="串口Password",blank=True,null=True)
    toolingMachine = models.CharField(max_length=255, verbose_name="工装机", blank=True,null=True)
    borrowUser = models.CharField(max_length=255, null=True, blank=True,verbose_name="借用人")
    borrowFromtime= models.DateField(null=True, blank=True, verbose_name="借用时间")
    borrowEndtime= models.DateField(null=True, blank=True,  verbose_name="归还时间")
    borrowUse= models.CharField(max_length=255, verbose_name="借用用途", blank=True,null=True)
    notes = models.TextField( verbose_name="备注", blank=True,null=True)
    missingStatus = models.BooleanField( default=True, verbose_name="联通状态")
    recordStatus =models.BooleanField( default=False,verbose_name="备案不下电")
    jumpserver = models.ForeignKey(JumpServers, on_delete=models.SET_NULL,null=True,  verbose_name='跳板机')
    class Meta:
        db_table = 'tb_servers_info'
        verbose_name = '服务器信息'
        verbose_name_plural = verbose_name
    def __str__(self):
        return self.serverscode

class HostOffRecord(CoreModel):
    """下电记录"""
    servers = models.ForeignKey(ServersInfo, on_delete=models.PROTECT, verbose_name='整机')
    status = models.BooleanField( verbose_name="下电是否成功")
    class Meta:
        db_table = 'tb_servers_hostoffrecord'
        verbose_name = 'host下电记录'
        verbose_name_plural = verbose_name

class ServersUseRecord(CoreModel):
    """整机使用记录"""
    servers = models.ForeignKey(ServersInfo, on_delete=models.CASCADE, verbose_name='整机')
    borrowUser = models.CharField(max_length=255,verbose_name="借用人", blank=True)
    borrowFromtime= models.DateField(null=True, blank=True, verbose_name="借用时间")
    borrowEndtime= models.DateField(null=True, blank=True,  verbose_name="归还时间")
    class Meta:
        db_table = 'tb_servers_useRecord'
        verbose_name = '整机使用记录'
        verbose_name_plural = verbose_name

############views.py

import openpyxl
from django.db.models import Count, Q, Case, When, IntegerField, Value
from django.utils.timezone import now
from django_filters.rest_framework import DjangoFilterBackend
from apps.wholeMachine.models import ServersUsage, ServersModel, ServersInfo
from rest_framework import serializers
from apps.wholeMachine.mytools import is_valid_date
from utils.export_excel import export_excel
from utils.jsonResponse import SuccessResponse, ErrorResponse
from utils.serializers import CustomModelSerializer
from utils.viewset import CustomModelViewSet
class ServersUsageManageSerializer(CustomModelSerializer):
    """
    服务器用途-序列化器
    """
    class Meta:
        model = ServersUsage
        read_only_fields = ["id"]
        fields = '__all__'
class ServersUsageManageViewSet(CustomModelViewSet):
    """
    服务器用途 接口
    """
    queryset = ServersUsage.objects.all().order_by("sort")
    serializer_class = ServersUsageManageSerializer
    search_fields = ('name','status')
class ServersModelManageSerializer(CustomModelSerializer):
    """
    服务器机型-序列化器
    """
    class Meta:
        model = ServersModel
        read_only_fields = ["id"]
        fields = '__all__'

class ServersModelManageSerializer_UsageandModel(serializers.Serializer):
    serversUsage__name = serializers.CharField()
    serversUsage = serializers.CharField()
    serversModel__name= serializers.CharField()
    serversModel= serializers.CharField()
    serversCount = serializers.IntegerField()
    serversCount_dis = serializers.IntegerField()
class ServersModelManageViewSet(CustomModelViewSet):
    """
    服务器机型 接口
    """
    queryset = ServersModel.objects.all().order_by("sort")
    serializer_class = ServersModelManageSerializer
    search_fields = ('name',)
    filterset_fields = ('status','area',)
    def getArea(self,request,*args, **kwargs):
        queryset =  ServersModel.objects.values('area')
        return SuccessResponse(data=queryset, msg='success')

class ServersInfoManageSerializer(CustomModelSerializer):
    """
    整机信息-序列化器
    """
    serversmodel_area = serializers.SerializerMethodField(read_only=True)
    serversmodel_name = serializers.SerializerMethodField(read_only=True)
    serversusage_name = serializers.SerializerMethodField(read_only=True)
    def get_serversmodel_area(self,obj):
        if obj.serversModel :
            return obj.serversModel.area
    def get_serversmodel_name(self,obj):
        if obj.serversModel :
            return obj.serversModel.name
    def get_serversusage_name(self,obj):
        if obj.serversUsage :
            return obj.serversUsage.name
    class Meta:
        model = ServersInfo
        read_only_fields = ["id"]
        fields = '__all__'

class ExportServersInfoManageSerializer(CustomModelSerializer):
    """
    导出 整机信息 简单序列化器
    """
    serversmodel_area = serializers.SerializerMethodField(read_only=True)
    serversusage_name = serializers.SerializerMethodField(read_only=True)
    serversmodel_name = serializers.SerializerMethodField(read_only=True)
    def  get_serversmodel_area(self,obj):
        if obj.serversModel :
            return obj.serversModel.area
    def get_serversusage_name(self,obj):
        if obj.serversUsage :
            return obj.serversUsage.name
    def get_serversmodel_name(self,obj):
        if obj.serversModel :
            return obj.serversModel.name
    class Meta:
        model = ServersInfo
        fields = ('serverCode', 'location','serversmodel_area', 'serversusage_name','serversmodel_name','bmcip','bmcuser','bmcpassword','serialIP','serialPort')
# class ServersInfoCountSerializer_TypeandModel(serializers.Serializer):
#     serversModel__area = serializers.CharField()
#     serversModel__name= serializers.CharField()
#     serversModel= serializers.CharField()
#     serversCount = serializers.IntegerField()
#     serversCount_dis = serializers.IntegerField()
#     serversCount_nouse = serializers.IntegerField()


class ServersInfoManageViewSet(CustomModelViewSet):
    """
    整机信息 接口
    """
    queryset = ServersInfo.objects.filter(status=1).order_by("-create_datetime")
    # queryset = ServersInfo.objects.all().order_by("-create_datetime")
    serializer_class =  ServersInfoManageSerializer
    create_serializer_class =  ServersInfoManageSerializer
    update_serializer_class =ServersInfoManageSerializer
    filter_backends = [DjangoFilterBackend]
    filterset_fields = {
        'serverCode': ['icontains'],
        'serverFrom': ['icontains'],
        'hardware': ['icontains'],
        'borrowEndtime': ['lte'],
        'serversUsage': ['exact'],
        'serversModel': ['exact'],
        'serversModel__area': ['exact'],
    }
    search_fields = ('serverCode', 'serverFrom', 'hardware')
    def get_queryset(self):
        queryset = super().get_queryset()
        search_param = self.request.query_params.get('search', None)
        borrow_user_is_null = self.request.query_params.get('borrowUserIsNull', None)
        borrow_endtime_earlier_param = self.request.query_params.get('borrowEndtimeEarlierThan', None)
        borrow_endtime_later_param = self.request.query_params.get('borrowEndtimeLaterThan', None)
        if borrow_user_is_null is not None:
            borrow_user_is_null = borrow_user_is_null.lower()=='true'
            queryset = queryset.filter(borrowUser__isnull=borrow_user_is_null)
        if search_param:
            queryset = queryset.filter(
                Q(serverCode__icontains=search_param) |
                Q(serverFrom__icontains=search_param) |
                Q(hardware__icontains=search_param)|
                Q(bmcIP__icontains=search_param)
            )
        if borrow_endtime_earlier_param:
            queryset = queryset.filter(
                Q(borrowEndtime__lt=borrow_endtime_earlier_param) | Q(borrowEndtime__isnull=True)
            )
        if borrow_endtime_later_param:
            queryset = queryset.filter(
                Q(borrowEndtime__gte=borrow_endtime_later_param) | Q(borrowEndtime__isnull=True)
            )
        return queryset


    def countAll(self,request,*args, **kwargs):
        total_books = ServersInfo.objects.count()
        serversCount_dis = ServersInfo.objects.filter(missingStatus=0).count()
        data = {
            'total_books': total_books,
            'serversCount_dis':serversCount_dis,
        }
        return SuccessResponse(data=data, msg='success')

    def countbyAreaandModel(self,request,*args, **kwargs):
        current_date = now().date()
        queryset =  ServersInfo.objects.values('serversModel__area', 'serversModel__name','serversModel').annotate(
            serversCount=Count('id'),
            serversCount_dis=Count('id', filter=Q(missingStatus=0)),
            serversCount_nouse=Count(
                Case(
                    When(
                        Q(serversUsage__name='公共资源') &
                        ((Q(borrowEndtime__lt=current_date) & Q(borrowUser__isnull=False)) |
                         Q(borrowUser__isnull=True)),
                        then=Value(1)
                    ),
                    output_field=IntegerField()
                )
            ),
            serversCount_inuse=Count(
                Case(
                    When(
                        Q(serversUsage__name='公共资源') &
                        (Q(borrowEndtime__gte=current_date) | Q(borrowEndtime__isnull=True)) &
                        Q(borrowUser__isnull=False),
                        then=Value(1)
                    ),
                    output_field=IntegerField()
                )
            )
        ).order_by('-serversCount')
        # serializer = ServersInfoCountSerializer_TypeandModel(queryset, many=True)
        return SuccessResponse(data=queryset, msg='success')
    def countbyArea(self,request,*args, **kwargs):
        current_date = now().date()
        queryset =  ServersInfo.objects.values('serversModel__area').annotate(
            serversCount=Count('id'),
            serversCount_dis = Count('id', filter=Q(missingStatus=0)),
            serversCount_nouse=Count(
                Case(
                    When(
                        Q(serversUsage__name='公共资源') &
                        ((Q(borrowEndtime__lt=current_date) & Q(borrowUser__isnull=False)) |
                         Q(borrowUser__isnull=True)),
                        then=Value(1)
                    ),
                    output_field=IntegerField()
                )
            ),
            serversCount_inuse=Count(
                Case(
                    When(
                        Q(serversUsage__name='公共资源') &
                        (Q(borrowEndtime__gte=current_date) | Q(borrowEndtime__isnull=True))&
                        Q(borrowUser__isnull=False),
                        then=Value(1)
                    ),
                    output_field=IntegerField()
                )
            )
        ).order_by('-serversCount')
        return SuccessResponse(data=queryset, msg='success')

    def countbyUsageandModel(self,request,*args, **kwargs):
        current_date = now().date()
        queryset =  ServersInfo.objects.values('serversModel__name','serversUsage__name','serversModel','serversUsage').annotate(
            serversCount=Count('id'),
            serversCount_dis = Count('id', filter=Q(missingStatus=0)),
            serversCount_nouse=Count(
                Case(
                    When(
                        Q(serversUsage__name='公共资源') &
                        ((Q(borrowEndtime__lt=current_date) & Q(borrowUser__isnull=False)) |
                         Q(borrowUser__isnull=True)),
                        then=Value(1)
                    ),
                    output_field=IntegerField()
                )
            ),
            serversCount_inuse=Count(
                Case(
                    When(
                        Q(serversUsage__name='公共资源') &
                        (Q(borrowEndtime__gte=current_date) | Q(borrowEndtime__isnull=True)) &
                        Q(borrowUser__isnull=False),
                        then=Value(1)
                    ),
                    output_field=IntegerField()
                )
            )

        ).order_by('-serversModel__name','-serversCount')
        # serializer = ServersInfoCountSerializer_UsageandModel(queryset, many=True)
        return SuccessResponse(data=queryset, msg='success')
    def countbyUsage(self,request,*args, **kwargs):
        current_date = now().date()
        queryset =  ServersInfo.objects.values('serversUsage__name','serversUsage').annotate(
            serversCount=Count('id'),
            serversCount_dis = Count('id', filter=Q(missingStatus=0)),
            serversCount_nouse=Count(
                Case(
                    When(
                        Q(serversUsage__name='公共资源') &
                        ((Q(borrowEndtime__lt=current_date) & Q(borrowUser__isnull=False)) |
                         Q(borrowUser__isnull=True)),
                        then=Value(1)
                    ),
                    output_field=IntegerField()
                )
            ),
            serversCount_inuse=Count(
                Case(
                    When(
                        Q(serversUsage__name='公共资源') &
                        (Q(borrowEndtime__gte=current_date) | Q(borrowEndtime__isnull=True))&
                        Q(borrowUser__isnull=False),
                        # queryset=queryset.filter(borrowUser__isnull=borrow_user_is_null)
                        then=Value(1)
                    ),
                    output_field=IntegerField()
                )
            )
        ).order_by('-serversCount')
        return SuccessResponse(data=queryset, msg='success')

    def exportexecl(self, request):
        field_data =  ['服务器编号', '服务器位置', '整机类别', '整机用途', '整机型号', 'BMCIP','bmcuser','bmcpassword','串口地址','串口端口']
        queryset = self.filter_queryset(self.get_queryset())
        data = ExportServersInfoManageSerializer(queryset, many=True).data
        return SuccessResponse(data=export_excel(request, field_data, data, '服务器数据.xls'), msg='success')

    def importexcel(self,request, *args, **kwargs):
        """
        导入execl中字段如果为数字会自动加.0 ,解决方法:execl设置该列为文本型
        """
        f = request.FILES.get('file')
        if not f:
            return ErrorResponse(msg="未找到上传的文件")
        excel_type = f.name.split('.')[1]
        if excel_type not in ['xlsx']:
            return ErrorResponse(msg="仅允许导入xlsx文件")
        workbook = openpyxl.load_workbook(filename=f,read_only=True)
        sheet = workbook.active
        data_import_list = []
        error_import_list = []
        rowsnum=1
        existing_server_codes = set(ServersInfo.objects.values_list('serverCode', flat=True))
        for rowvalue in sheet.iter_rows(min_row=2, values_only=True):
            rowsnum = rowsnum+1
            errordict={}
            errordict['rowsnum']= rowsnum
            serverCode = rowvalue[2]
            if serverCode is not None:
                # serverCode = serverCode.replace(' ', '')
                serverCode = serverCode.strip()
            else:
                errordict['serverCode'] = f'设备编号错误----{serverCode}'
                error_import_list.append(errordict)
                continue
            if serverCode in existing_server_codes:
                errordict['serverCode'] = f'serverCode 重复----{serverCode}'
                error_import_list.append(errordict)
                continue
            serversUsage =rowvalue[5]
            if serversUsage != None:
                serversUsage =rowvalue[5].replace(' ', '')
            else:
                errordict['serversUsage'] = f'设备用途错误----{serversUsage}'
                error_import_list.append(errordict)
                continue
            servers_Info_obj=False
            try:
                servers_Info_obj =  ServersInfo.objects.get(serverCode=serverCode)
            except :
                print('')
            if servers_Info_obj:
                errordict['serverCode'] = f'serverCode重复----{serverCode}'
                error_import_list.append(errordict)
                continue
            serversModel=''
            index = serverCode.find('-')
            print()
            if index != -1:
                serversModel=serverCode[:index]
            else:
                serversModel = serverCode
            try:
                servers_model_obj = ServersModel.objects.get(name=serversModel)
            except ServersModel.DoesNotExist as e:
                errordict['ServersModel']=f'设备机型不在机型列表中---{serversModel}'
                error_import_list.append(errordict)
                continue
            try:
                servers_Usage_obj =ServersUsage.objects.get(name=rowvalue[5])
            except ServersUsage.DoesNotExist as e:
                errordict['ServersUsage'] = f'设备用途不在用途列表中---{rowvalue[5]}'
                error_import_list.append(errordict)
                continue
            borrowFromtime = rowvalue[9]
            borrowEndtime = rowvalue[10]
            if borrowFromtime!=None:
                borrowFromtime=borrowFromtime.replace(' ', '').replace('\ufeff','')
                if borrowFromtime!=''and is_valid_date(borrowFromtime) == False:
                    errordict['borrowFromtime'] = f'borrowFromtime日期格式不对---{borrowFromtime}'
                    error_import_list.append(errordict)
                    continue
                if borrowFromtime == '':
                    borrowFromtime = None
            if borrowEndtime != None:
                borrowEndtime= borrowEndtime.replace(' ', '').replace('\ufeff','')
                if borrowEndtime!='' and is_valid_date(borrowEndtime) == False:
                    errordict['borrowEndtime'] = f'borrowEndtime日期格式不对---{borrowEndtime}'
                    error_import_list.append(errordict)
                    continue
                if borrowEndtime == '':
                    borrowEndtime = None
            borrowUser = rowvalue[8]
            if borrowUser != None:
                borrowUser=borrowUser.replace(' ', '').replace('\ufeff','')
                if len(borrowUser) > 130:
                    errordict['borrowUser'] = f'borrowUser数据错误---{borrowUser}'
                    error_import_list.append(errordict)
                    continue
                if borrowUser=='':
                    borrowUser = None

            try:
                data_dict = {
                    'serverFrom':rowvalue[1] ,
                    'serverCode':serverCode,
                    'serversModel':servers_model_obj ,
                    'location':rowvalue[3],
                    'hardware':rowvalue[4],
                    'serversUsage':servers_Usage_obj,
                    'bmcIP':rowvalue[6],
                    'hostIP':rowvalue[7],
                    'borrowUser':borrowUser,
                    'borrowFromtime':borrowFromtime,
                    'borrowEndtime':borrowEndtime,
                    'borrowUse':rowvalue[11],
                    'notes':rowvalue[12]
                }
                obj = ServersInfo(**data_dict)
                data_import_list.append(obj)
                existing_server_codes.add(serverCode)  # 将当前 serverCode 添加到已存在集合中
            except Exception as e:
                errordict['datachange'] = e
                error_import_list.append(errordict)
                continue
        lenObjects=len(data_import_list)
        lenOerror=len(error_import_list)
        ServersInfo.objects.bulk_create(data_import_list)
        return SuccessResponse(data= error_import_list, msg=f"导入{lenObjects}行,错误行数{lenOerror}")

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/70900.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PDF处理控件Aspose.PDF教程:使用 Python 将 PDF 转换为 TIFF

TIFF文件是高质量图像的首选。它们广泛用于印刷、存档和图形设计。企业通常需要转换PDF文档以获得更好的兼容性。了解如何以编程方式执行此转换可以节省时间和资源。在这篇教程中&#xff0c;我们将探讨如何使用 Python 将 PDF 转换为 TIFF。 本文涵盖以下主题&#xff1a; P…

服务器IPMI用户名、密码批量检查

背景 大规模服务器部署的时候&#xff0c;少不了较多的网管和监测平台&#xff0c;这些平台会去监控服务器的性能、硬件等指标参数&#xff0c;为了便于管理和控制&#xff0c;则需要给服务器IPMI带外管理添加较多的用户&#xff0c;这就需要对较多的服务器检查所对应的IPMI用…

< 自用文儿 > Gobuster 暴力扫描工具与 SecLists 安全测试词表集合

Ethice 道德问题 GFW 的保护下&#xff0c;很多的设备操作系统是停留在更老的版本&#xff0c;应用软件也是&#xff0c;因此很多的漏洞没有被修复。通讯没有使用加密&#xff0c;例如网页没有使用 HTTPS 网站很多。几乎是半裸的在网络上等着被食。 不做恶是下限。 环境&…

【Cadence射频仿真学习笔记】2.4GHz低噪放LNA仿真设计

课程分为3个部分&#xff0c; 一、LNA结构与噪声优化方法 噪声优化的方法是&#xff1a;限定功耗的噪声和功率同时匹配噪声匹配和功率匹配一般不会同时达到&#xff0c; 对于PCSNIM结构的噪声分析&#xff0c;我们只需要了解与哪些参数有关优化思路是&#xff1a;1.信号源阻抗…

【洛谷入门赛】B4042 顺序结构 202410 场

题意 给你一个变量 a a a&#xff1a;小 Y 会让 a a a 先加 5 5 5 再把它们的和乘 3 3 3 最后输出&#xff1b;小 L 会让 a a a 先乘 3 3 3 再加 5 5 5 最后输出。 要求出小 Y 和小 L 分别会输出什么东西。 思路 这道题按照题目意思模拟就可以了&#xff0c;重点是考…

【Azure 架构师学习笔记】- Azure Databricks (13) -- 搭建Medallion Architecture part 1

本文属于【Azure 架构师学习笔记】系列。 本文属于【Azure Databricks】系列。 接上文 【Azure 架构师学习笔记】- Azure Databricks (12) – Medallion Architecture简介 前言 上文已经介绍了关于Medallion的知识&#xff0c;本文开始用ADB 来实现&#xff0c; 但是基于内容较…

社交APP如何打造高粘性兴趣社群

想要打造一款成功的社交 APP 兴趣社群&#xff0c;关键在于充分激发用户的主动分享意愿&#xff0c;同时构建起深度互动机制。与其在一开始就将大量资源投入到广告宣传中&#xff0c;倒不如把精力集中在深度挖掘和精心维护首批核心用户上。例如&#xff0c;可以尝试设计在线测试…

【操作系统】同步与互斥

同步与互斥 一、同步与互斥的概念1.1 同步与异步1.2 进程互斥 二、进程互斥的实现2.1 软件实现2.1.1 单标志法2.1.2 双标志先检查法2.1.3 双标志后检查法2.1.4 Peterson法 2.2 硬件实现2.2.1 中断指令2.2.2 TestAndSet指令2.2.3 Swap指令 三、互斥锁四、信号量机制4.1 整型信号…

性能附录:如何计算并发用户数(摘自高楼老师《性能30讲》)

高楼老师《性能30讲》: 性能测试实战30讲-极客时间 感兴趣的同学可以去读一下&#xff0c;个人感觉写的非常好 目录 什么是并发? 在线用户数、并发用户数怎么计算 总结 什么是并发? 我们假设上图中的这些小人是严格按照这个逻辑到达系统的&#xff0c;那显然&#xff0c;…

基于yolov8的糖尿病视网膜病变严重程度检测系统python源码+pytorch模型+评估指标曲线+精美GUI界面

【算法介绍】 基于YOLOv8的糖尿病视网膜病变严重程度检测系统 基于YOLOv8的糖尿病视网膜病变严重程度检测系统是一款利用深度学习技术&#xff0c;专为糖尿病视网膜病变早期诊断设计的智能辅助工具。该系统采用YOLOv8目标检测模型&#xff0c;结合经过标注和处理的医学影像数…

学习路程八 langchin核心组件 Models补充 I/O和 Redis Cache

前序 之前了解了Models&#xff0c;Prompt&#xff0c;但有些资料又把这块与输出合称为模型输入输出&#xff08;Model I/O&#xff09;‌&#xff1a;这是与各种大语言模型进行交互的基本组件。它允许开发者管理提示&#xff08;prompt&#xff09;&#xff0c;通过通用接口调…

DeepSeek 开源狂欢周(五)正式收官|3FS并行文件系统榨干SSD

千呼万唤始出来&#xff01;在 DeepSeek 开源周 的第五天&#xff0c;今日正式收官&#xff01;在大模型训练中&#xff0c;每个epoch都在与存储系统进行光速竞赛——数据加载延迟会扭曲计算时空&#xff0c;KVCache访问瓶颈将引发推理坍缩。DeepSeek开源的 3FS文件系统&#x…

TCP基本入门-简单认识一下什么是TCP

部分内容来源&#xff1a;小林Coding TCP的特点 1.面向连接 一定是“一对一”才能连接&#xff0c;不能像 UDP 协议可以一个主机同时向多个主机发送消息&#xff0c;也就是一对多是无法做到的 2.可靠的 无论的网络链路中出现了怎样的链路变化&#xff0c;TCP 都可以保证一个…

PING命令TTL解析

在 ping 命令中&#xff0c;TTL&#xff08;Time to Live&#xff0c;生存时间&#xff09; 是 IP 数据包的核心字段之一&#xff0c;用于控制数据包在网络中的生命周期。以下是针对 TTL 的简明解析&#xff1a; 1. TTL 的核心作用 防循环机制&#xff1a;TTL 是一个计数器&a…

PySide(PyQT)重新定义contextMenuEvent()实现鼠标右键弹出菜单

在 PySide中&#xff0c;contextMenuEvent() 是 QWidget 类&#xff08;以及继承自它的所有子类&#xff09;的一个事件处理方法&#xff0c;主要用于处理上下文菜单事件&#xff0c;也就是当用户在控件上右键点击时触发的事件。 • 通过重新定义contextMenuEvent()来实现自定…

Go红队开发—并发编程

文章目录 并发编程go协程chan通道无缓冲通道有缓冲通道创建⽆缓冲和缓冲通道 等协程sync.WaitGroup同步Runtime包Gosched()Goexit() 区别 同步变量sync.Mutex互斥锁atomic原子变量 SelectTicker定时器控制并发数量核心机制 并发编程阶段练习重要的细节端口扫描股票监控 并发编程…

RabbitMQ 的介绍与使用

一. 简介 1> 什么是MQ 消息队列&#xff08;Message Queue&#xff0c;简称MQ&#xff09;&#xff0c;从字面意思上看&#xff0c;本质是个队列&#xff0c;FIFO先入先出&#xff0c;只不过队列中存放的内容是message而已。 其主要用途&#xff1a;不同进程Process/线程T…

常用的AI文本大语言模型汇总

AI文本【大语言模型】 1、文心一言https://yiyan.baidu.com/ 2、海螺问问https://hailuoai.com/ 3、通义千问https://tongyi.aliyun.com/qianwen/ 4、KimiChat https://kimi.moonshot.cn/ 5、ChatGPThttps://chatgpt.com/ 6、魔塔GPT https://www.modelscope.cn/studios/iic…

在自己的数据上复现一下LlamaGen

git仓库&#xff1a;https://github.com/FoundationVision/LlamaGen 数据集准备 如果用ImageFolder读取&#xff0c;则最好和ImageNet一致。 data_path/class_1/image_001.jpgimage_002.jpg...class_2/image_003.jpgimage_004.jpg......class_n/image_005.jpgimage_006.jpg.…

【数据结构进阶】哈希表

&#x1f31f;&#x1f31f;作者主页&#xff1a;ephemerals__ &#x1f31f;&#x1f31f;所属专栏&#xff1a;数据结构 目录 前言 一、哈希表的概念 二、哈希函数的实现方法 1. 直接定址法 2. 除留余数法 三、哈希冲突 1. 开放定址法&#xff08;闭散列&#xff0…