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 复制代码
再次执行就成功了...
相关推荐
o(╥﹏╥)28 分钟前
linux(ubuntu )卡死怎么强制重启
linux·数据库·ubuntu·系统安全
阿里嘎多学长42 分钟前
docker怎么部署高斯数据库
运维·数据库·docker·容器
Yuan_o_1 小时前
Linux 基本使用和程序部署
java·linux·运维·服务器·数据库·后端
Sunyanhui11 小时前
牛客网 SQL36查找后排序
数据库·sql·mysql
老王笔记1 小时前
MHA binlog server
数据库·mysql
lovelin+v175030409662 小时前
安全性升级:API接口在零信任架构下的安全防护策略
大数据·数据库·人工智能·爬虫·数据分析
isSamle2 小时前
使用Vue+Django开发的旅游路书应用
前端·vue.js·django
DT辰白3 小时前
基于Redis的网关鉴权方案与性能优化
数据库·redis·缓存
2401_871213303 小时前
mysql高阶语句
数据库·mysql