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 复制代码
再次执行就成功了...
相关推荐
亿坊电商22 分钟前
PHP后端项目中多环境配置管理:开发、测试、生产的优雅解决方案!
服务器·数据库·php
韩立学长23 分钟前
基于Springboot的影视评论网站的设计与实现58py6238(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
未来之窗软件服务1 小时前
未来之窗昭和仙君(四十七)开发商品进销存——东方仙盟筑基期
数据库·进销存·仙盟创梦ide·东方仙盟·昭和仙君·东方仙盟架构
IDOlaoluo2 小时前
TinyRDM 1.2.3 Windows版安装教程(附Redis客户端下载及详细步骤)
数据库·redis·缓存
小光学长2 小时前
基于微信小程序的背单词系统x1o5sz72(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·微信小程序·小程序
我命由我123454 小时前
Derby - Derby 服务器(Derby 概述、Derby 服务器下载与启动、Derby 连接数据库与创建数据表、Derby 数据库操作)
java·运维·服务器·数据库·后端·java-ee·后端框架
RestCloud5 小时前
达梦数据库到Greenplum:用ETL工具实现数据仓库迁移
数据库·数据仓库·etl·达梦数据库·数据传输·greenplum
Boilermaker19926 小时前
【Redis】集群与分布式缓存
java·数据库·redis·1024程序员节
武子康6 小时前
Java-163 MongoDB 生产安全加固实战:10 分钟完成认证、最小权限、角色详解
java·数据库·分布式·mongodb·性能优化·系统架构·nosql
zhangyifang_0096 小时前
PostgreSQL 的表继承与分区
数据库·postgresql