ホームページ > バックエンド開発 > Python チュートリアル > JSON 処理時に Python でエラー レポートとエンコード エラー レポートを評価するための 2 つの実際のソリューション

JSON 処理時に Python でエラー レポートとエンコード エラー レポートを評価するための 2 つの実際のソリューション

WBOY
リリース: 2016-07-06 13:29:46
オリジナル
1476 人が閲覧しました

1、ValueError: Invalid control character at: line 1 column 8363 (char 8362)
使用json.loads(json_data)时,出现:

ValueError: Invalid control character at: line 1 column 8363 (char 8362)
ログイン後にコピー

出现错误的原因是字符串中包含了回车符(\r)或者换行符(\n)
解决方法:
(1)对这些字符转义:

json_data = json_data.replace('\r', '\\r').replace('\n', '\\n')
ログイン後にコピー

(2)使用关键字strict:

json.loads(json_data, strict=False)
ログイン後にコピー

strict默认是True,它将严格控制内部字符串,将其设置为False,便可以允许你\n \r。


2、UnicodeEncodeError: ascii codec can't encode错误
在windows下写的python脚本,放到linux下运行,直接报:

UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-11: ordinal not in range(128)

出错原因是Python2.7在安装时,默认的编码是ascii,当程序中出现非ascii编码时,Python的处理常常会报这样的错,不过在Python3中就不会有这样的问题。
解决方法:
(1)临时解决方法:
在代码前加入:

import sys 
reload(sys) 
sys.setdefaultencoding('utf8')
ログイン後にコピー

(2)一劳永逸:
在Python的lib\site-packages文件夹下新建一个sitecustomize.py,内容如下:

# encoding=utf8 
import sys 

reload(sys) 
sys.setdefaultencoding('utf8')

ログイン後にコピー

这样的话,系统在Python启动的时候,自行调用该文件,设置系统的默认编码。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート