Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/python-3.x/19.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Django Unittest无法使用TypeError运行:isinstance()arg 2必须是一台计算机上的类型或类型元组,而不是其他计算机上的类型或类型元组_Django_Python 3.x - Fatal编程技术网

Django Unittest无法使用TypeError运行:isinstance()arg 2必须是一台计算机上的类型或类型元组,而不是其他计算机上的类型或类型元组

Django Unittest无法使用TypeError运行:isinstance()arg 2必须是一台计算机上的类型或类型元组,而不是其他计算机上的类型或类型元组,django,python-3.x,Django,Python 3.x,由于某些原因,我无法在我的Windows计算机上运行“manage.py test AppNameHere”,但当我在linux计算机上运行它时(我不确定这里的操作系统是否真正重要),测试运行正常。我得到这个错误: 2019-01-11 17:35:32 [DEBUG] faker.factory: Not in REPL -> leaving logger event level as is. Creating test database for alias 'default'... Trac

由于某些原因,我无法在我的Windows计算机上运行“manage.py test AppNameHere”,但当我在linux计算机上运行它时(我不确定这里的操作系统是否真正重要),测试运行正常。我得到这个错误:

2019-01-11 17:35:32 [DEBUG] faker.factory: Not in REPL -> leaving logger event level as is. Creating test database for alias 'default'... Traceback (most recent call last): File "manage.py", line 22, in execute_from_command_line(sys.argv) File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\core\management\__init__.py", line 381, in execute_from_command_line utility.execute() File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\core\management\__init__.py", line 375, in execute self.fetch_command(subcommand).run_from_argv(self.argv) File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\core\management\commands\test.py", line 26, in run_from_argv super().run_from_argv(argv) File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\core\management\base.py", line 316, in run_from_argv self.execute(*args, **cmd_options) File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\core\management\base.py", line 353, in execute output = self.handle(*args, **options) File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\core\management\commands\test.py", line 56, in handle failures = test_runner.run_tests(test_labels) File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\test\runner.py", line 604, in run_tests old_config = self.setup_databases() File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\test\runner.py", line 551, in setup_databases self.parallel, **kwargs File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\test\utils.py", line 174, in setup_databases serialize=connection.settings_dict.get('TEST', {}).get('SERIALIZE', True), File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\db\backends\base\creation.py", line 68, in create_test_db run_syncdb=True, File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\core\management\__init__.py", line 148, in call_command return command.execute(*args, **defaults) File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\core\management\base.py", line 353, in execute output = self.handle(*args, **options) File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\core\management\base.py", line 83, in wrapped res = handle_func(*args, **kwargs) File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\core\management\commands\migrate.py", line 203, in handle fake_initial=fake_initial, File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\db\migrations\executor.py", line 117, in migrate state = self._migrate_all_forwards(state, plan, full_plan, fake=fake, fake_initial=fake_initial) File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\db\migrations\executor.py", line 147, in _migrate_all_forwards state = self.apply_migration(state, migration, fake=fake, fake_initial=fake_initial) File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\db\migrations\executor.py", line 244, in apply_migration state = migration.apply(state, schema_editor) File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\db\migrations\migration.py", line 124, in apply operation.database_forwards(self.app_label, schema_editor, old_state, project_state) File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\db\migrations\operations\fields.py", line 84, in database_forwards field, File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\db\backends\sqlite3\schema.py", line 309, in add_field self._remake_table(model, create_field=field) File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\db\backends\sqlite3\schema.py", line 181, in _remake_table self.effective_default(create_field) File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\db\backends\base\schema.py", line 218, in effective_default default = field.get_default() File "C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\db\models\fields\related.py", line 927, in get_default if isinstance(field_default, self.remote_field.model): TypeError: isinstance() arg 2 must be a type or tuple of types 2019-01-11 17:35:32[DEBUG]faker.factory:不在REPL->保持记录器事件级别不变。 正在为别名“default”创建测试数据库。。。 回溯(最近一次呼叫最后一次): 文件“manage.py”,第22行,在 从命令行(sys.argv)执行命令 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\core\management\\ uuuuuuuu init\uuuuuuuuuu.py”,第381行,从命令行执行 utility.execute() 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\core\management\\ uuuuuu init\uuuuuu.py”,第375行,在execute中 self.fetch_命令(子命令)。从_argv(self.argv)运行_ 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site-packages\django\core\management\commands\test.py”,第26行,从\u argv运行 super()。从_argv(argv)运行_ 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\core\management\base.py”,第316行,运行于\u argv self.execute(*args,**cmd_选项) 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\core\management\base.py”,执行中第353行 输出=self.handle(*args,**选项) 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\core\management\commands\test.py”,第56行,在handle中 失败=测试运行程序。运行测试(测试标签) 运行测试中的文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\test\runner.py”,第604行 old\u config=self.setup\u databases() 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\test\runner.py”,第551行,位于setup\u数据库中 self.parallel,**kwargs 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\test\utils.py”,第174行,位于setup\u数据库中 serialize=connection.settings\u dict.get('TEST',{}).get('serialize',True), 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\db\backends\base\creation.py”,第68行,在create\u test\u db中 运行\u syncdb=True, 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\core\management\\ uuuuuuu init\uuuuuu.py”,第148行,在call\u命令中 return命令。execute(*args,**默认值) 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\core\management\base.py”,执行中第353行 输出=self.handle(*args,**选项) 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\core\management\base.py”,第83行,已包装 res=句柄函数(*args,**kwargs) 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\core\management\commands\migrate.py”,第203行,位于句柄中 假首字母=假首字母, 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\db\migrations\executor.py”,第117行,在migrate中 状态=self.\u迁移\u所有\u转发(状态,计划,完整计划,假=假,假首字母=假首字母) 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\db\migrations\executor.py”,第147行,全部向前迁移 state=self.apply\u迁移(state,migration,false=false,false\u initial=false\u initial) 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\db\migrations\executor.py”,第244行,在apply\u migration中 state=migration.apply(状态,模式编辑器) 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\db\migrations\migration.py”,第124行,在apply中 操作。数据库转发(self.app\u标签、模式编辑器、旧状态、项目状态) 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\db\migrations\operations\fields.py”,第84行,在数据库中 领域 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\db\backends\sqlite3\schema.py”,第309行,在add\u字段中 self.\u重新制作表(模型,创建字段=字段) 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\db\backends\sqlite3\schema.py”,第181行,在表中 自生效\u默认值(创建\u字段) 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\db\backends\base\schema.py”,第218行,默认有效 默认值=字段。获取默认值() 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\db\models\fields\related.py”,第927行,默认为get\u 如果isinstance(字段\默认值,self.remote \字段.model): TypeError:isinstance()arg 2必须是类型或类型的元组
看起来Django有问题,但我不确定。有人对此有什么见解吗?我不想从跟踪中修改这些文件,因为它们是Django的一部分。

更改代码怎么样 文件“C:\Users\personA\AppData\Local\Programs\Python\Python36-32\lib\site packages\django\db\models\fields\related.py”,第927行,默认为get\u

如果isinstance(字段默认值,键入(self.remote\u field.model)):

我通过以下方法解决了这个问题:

  • 删除我的所有迁移文件
  • 删除django_迁移表中的条目
  • 重新制作迁移(makemigrations)
  • 真的是假的吗

这里的问题是该文件属于Django库。我不想直接从文件中重写他们的代码。