Python Django开发 异常及解决办法(一)

CuterCorley
• 阅读 1545

1.ValueError: The view *** didn't return an HttpResponse object. It returned None instead

该错误表明views.py中没有return一个返回值给前端。 解决办法:检查 return HttpResponse()是否错位或者是否缺失。

2.NoReverseMatch: Reverse for 'xxx' not found . 'xxx' is not a valid view function or pattern

在templates里html文件模板用{% url ‘xxx’%}解析时没有跟app_name,具体如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>pagedetail</title>
</head>
<body>
    <div>
        <a href="{% url 'index' %}"> home </a>
    </div>
</body>
</html>

解决办法: 更改HTML文件中url标签部分: <a href="{% url 'test1_app:index' %}"> home </a>

3.python manage.py migrate,提示No migrations to apply

造成多次应用migrations失败的原因是,当前model是修改过的,原来的migrations已经被删除,但是,重新生成的migrations使用递增整数记名,所以,在django_migrations表中0001,0002等前面几个数字的文件都已被记录,在Django看来,被记录了就相当于已应用,所以,会出现刚开始的No migrations to apply。 解决方案: python manage.py dbshell 进到数据库中; 执行delete from django_migrations where app='your_appname'; python manage.py makemigrations(若migrations文件未删除,可不执行这一步); python manage.py migrate即可成功。

4.Django配置MySQL数据库时django.db.utils.OperationalError

Django默认配置的数据库为sqlite,为稳健性数据库,一般需要改为MySQL等数据库,settings.py需要修改如下:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'fresh_ec',
        'USER': 'root',
        'PASSWORD': 'root',
        'HOST':'127.0.0.1',
        'OPTIONS': {'init_command': 'SET storage_engine=INNODB;'}
    }
}

可能会报错,如:

django.db.utils.OperationalError: (1193, "Unknown system variable 'storeage_engine'")

即storage_engine参数错误,需要改为default_storage_engine,即:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'fresh_ec',
        'USER': 'root',
        'PASSWORD': 'root',
        'HOST':'127.0.0.1',
        'OPTIONS': {'init_command': 'SET default_storage_engine=INNODB;'}
    }
}

再次运行项目,即成功。

5.Django makemigrations报错Field specifies on_delete=SET_NULL, but cannot be null

在进行Django开发时,定义完数据模型后要进行数据映射,在执行makemigrations命令行后,可能会报错如下:

xxx.Xxx.xxxx: (fields.E320) Field specifies on_delete=SET_NULL, but cannot be null.
    HINT: Set null=True argument on the field, or change the on_delete rule.

这可能是因为所定义的某个模型定义了外键,而在新版的Django中外键必须指定on_delete属性,例如user = models.ForeignKey(User, verbose_name='用户', on_delete=models.SET_NULL)此时是因为该属性指定为models.SET_NULL,即在父模型删除数据后,对应的子模型记录字段设为空,但是在定义该字段时并未允许该字段为空,因此解决方法有两种:

  • 字段增加null属性为真 即字段定义为user = models.ForeignKey(User, verbose_name='用户', null=True, on_delete=models.SET_NULL)
  • 修改on_delete属性 修改该属性为其他值,如models.CASCADEmodels.SET_DEFAULT等。

6.Django xadmin数据迁移ImportError

在安装xadmin后进行数据迁移时,报错:

ImportError: cannot import name 'six' from 'django.utils'

这是因为django3及以上的版本中已经没有six插件,可以将django降到2版本,也可以将安装的six.py复制到django/utils目录下,操作如下: Python Django开发 异常及解决办法(一) 还需要修改xadmin的文件导入,xadmin/models.py修改如下:

import json
import django
from django.db import models
from django.utils import timezone
from django.conf import settings
from django.contrib.contenttypes.models import ContentType
from django.utils.translation import ugettext_lazy as _, ugettext
from django.urls import NoReverseMatch, reverse
from django.core.serializers.json import DjangoJSONEncoder
from django.db.models.base import ModelBase
from django.utils.encoding import smart_text
from django.utils.six import python_2_unicode_compatible

在其他文件中可能还会遇到同样的错误,按照相同的方法修改即可。

7.Django xadmin数据迁移init() takes 1 positional argument but 6 were given

在安装xadmin后进行数据迁移时,报错:

forms.Field.__init__(self, required, widget, label, initial, help_text,
TypeError: __init__() takes 1 positional argument but 6 were given

直接找到xadmin\views\dashboard.py,将forms.Field.__init__(self, required, widget, label, initial, help_text, *args, **kwargs)改为forms.Field.__init__(self)即可。

8.Django xadmin数据迁移ImportError

在安装xadmin后进行数据迁移时,报错:

from django.contrib.auth.views import password_reset_confirm
ImportError: cannot import name 'password_reset_confirm' from 'django.contrib.auth.views' (C:\Users\LENOVO\.virtualenvs\Django_Vue_Fresh_Ecommerce-NKba4OvD\lib\site-packages\django\contrib\auth\views.py)

此时需要修改xadmin\plugins\passwords.py,将rom django.contrib.auth.views import password_reset_confirm改为from django.contrib.auth.views import PasswordResetConfirmView,还需要将77行的return password_reset_confirm改为return PasswordResetConfirmView

9.Django xadmin数据迁移AttributeError: 'Settings' object has no attribute 'MIDDLEWARE_CLASSES'

在安装xadmin后进行数据迁移时,报错:

val = getattr(self._wrapped, name)
AttributeError: 'Settings' object has no attribute 'MIDDLEWARE_CLASSES'

此时需要修改xadmin\plugins\language.py,将第24行的if settings.LANGUAGES and 'django.middleware.locale.LocaleMiddleware' in settings.MIDDLEWARE_CLASSES:修改为if settings.LANGUAGES and 'django.middleware.locale.LocaleMiddleware' in settings.MIDDLEWARE:

10.Django xadmin数据迁移ModuleNotFoundError

在安装xadmin后进行数据迁移时,报错:

from django.core.urlresolvers import reverse
ModuleNotFoundError: No module named 'django.core.urlresolvers'

需要将报错文件的from django.core.urlresolvers import reverse修改为from django.urls import reverse

本文原文首发来自博客专栏Python Web开发实战,由本人转发至https://www.helloworld.net/p/GmaSV7tALU4J,其他平台均属侵权,可点击https://blog.csdn.net/CUFEECR/article/details/104031620查看原文,也可点击https://blog.csdn.net/CUFEECR浏览更多优质原创内容。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Wesley13 Wesley13
3年前
4cast
4castpackageloadcsv.KumarAwanish发布:2020122117:43:04.501348作者:KumarAwanish作者邮箱:awanish00@gmail.com首页:
Stella981 Stella981
3年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这