Django数据导出与导入问题

handlebars 复制代码
执行: python manage.py loaddata data.json 的常见错误:
* 1. UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 0: invalid start byte

* 2. raise JSONDecodeError("Unexpected UTF-8 BOM (decode using utf-8-sig)",
     ...
     django.core.serializers.base.DeserializationError: Problem installing fixture 'D:\MyDjango\data.json':
handlebars 复制代码
使用 python manage.py dumpdata > data.json 语句导出的文件编码为utf16(BOM符合无需理会)
使用  python manage.py loaddata data.json 语句导入文件报错:
UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 0: invalid start byte
handlebars 复制代码
万恶的PowerShell重定向时默认的文本编码是UTF-16LE, 简直反人类!
handlebars 复制代码
Pycharm中无法直接修改编码格式, 要求太多了...
handlebars 复制代码
使用Notepad2编辑器直接修改编码为UTF8.
handlebars 复制代码
再次执行, 则成功...
handlebars 复制代码
使用别的语句虽然创建了utf8文件, 但是加载的时候又出现了错误.
文件包含了一个UTF-8字节顺序标记(BOM), 而Django的JSON反序列化器期望的是没有BOM的UTF-8编码。
python 复制代码
# 使用Out-File 用于将输出重定向到文件中, 文件编码默认为UTF8(遗憾的是该版本不能默认NO-BOM)
python manage.py dumpdata | Out-File data.json 
# 或
python manage.py dumpdata | Out-File data.json -Encoding utf8
# 设置重定向编码为UTF8
$PSDefaultParameterValues['Out-File:Encoding'] = 'utf8'
handlebars 复制代码
万恶的PowerShell重定向时设置默认的文本编码为UTF-8时, 携带BOM, ....CCC!
handlebars 复制代码
错误信息显示你在尝试使用 python manage.py loaddata data.json 命令加载fixture时遇到了 
json.decoder.JSONDecodeError: Unexpected UTF-8 BOM (decode using utf-8-sig) 错误.
这表明导出的 data.json 文件包含了一个UTF-8字节顺序标记(BOM), 而Django的JSON反序列化器期望的是没有BOM的UTF-8编码.
handlebars 复制代码
别急这里Pycharm提供了移除BOM的功能...
handlebars 复制代码
再次执行就成功了...
相关推荐
静听山水2 分钟前
mysql语句执行过程
数据库·mysql
虽千万人 吾往矣20 分钟前
golang gorm
开发语言·数据库·后端·tcp/ip·golang
mariokkm44 分钟前
Django一分钟:在Django中怎么存储树形结构的数据,DRF校验递归嵌套模型的替代方案
数据库·django·sqlite
Wang's Blog2 小时前
Redis: 集群环境搭建,集群状态检查,分析主从日志,查看集群信息
数据库·redis
容器( ु⁎ᴗ_ᴗ⁎)ु.。oO2 小时前
MySQL事务
数据库·mysql
cyt涛4 小时前
MyBatis 学习总结
数据库·sql·学习·mysql·mybatis·jdbc·lombok
Rookie也要加油4 小时前
01_SQLite
数据库·sqlite
向上的车轮4 小时前
Django学习笔记五:templates使用详解
笔记·学习·django
liuxin334455664 小时前
教育技术革新:SpringBoot在线教育系统开发
数据库·spring boot·后端
少女的迷鹿5 小时前
Paper:NSG(Navigating Spreading-out Graph)
数据库