首页 > 代码库 > PostgreSQL copy 时提示:ERROR: invalid byte sequence for encoding "UTF8": 0xb3
PostgreSQL copy 时提示:ERROR: invalid byte sequence for encoding "UTF8": 0xb3
测试时使用三种文件格式:
ISO-8859
Netpbm PBM image
ASCII
if [ $(file $filename|grep -c "ISO-8859") -gt 0 ]
then
echo "ISO-8859" psql -c "copy $schemaname.$tbname from ‘$dirname/$filename‘ with(format ‘csv‘, delimiter ‘, encoding ‘ISO-8859-1‘)" $dbname elif [ $(file $filename|grep -c "ASCII") -gt 0 ]
then
echo $format psql -c "copy $schemaname.$tbname from ‘$dirname/$filename‘ with(format ‘csv‘, delimiter ‘, encoding ‘UTF-8‘)" $dbname else psql -c "copy $schemaname.$tbname from ‘$dirname/$filename‘ with(format ‘csv‘, delimiter ‘, encoding ‘ISO-8859-1‘)" $dbname
这种处理方式在文件格式为ASCII时,copy中途仍然会出现编码错误提示。
ERROR: invalid byte sequence for encoding "UTF8": 0xb3
最后摸索发现不管什么格式,都指定为ISO-8859-1就能处理。
全包容的编码格式,都能处理:
psql -c "copy $schemaname.$tbname from ‘$dirname/$filename‘ with(format ‘csv‘, delimiter ‘, encoding ‘ISO-8859-1‘)" $dbname
PostgreSQL copy 时提示:ERROR: invalid byte sequence for encoding "UTF8": 0xb3
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。