我正在尝试读取json并获取其值。 我有一个包含JSON档案的文件夹,我需要打开所有档案并从中获取值。
这是代码:
# -*- encoding: utf-8 -*-
from pprint import pprint
import json
import os
def start():
for dirname, dirnames, filenames in os.walk('test'):
for filename in filenames:
json_file = open(os.path.join(dirname, filename)).read()
# json_file = unicode(json_file, 'utf-8')
json_data = json.loads(json_file)
pprint(json_data)
for key, value in json_data.items():
print "KEY : ", key
print "VALUE: ", value
start()
这是JSON的一个
{ "test" : "Search User 1",
"url" : "http://127.0.0.1:8000/api/v1/user/1/?format=json",
"status_code" : 200,
"method" : "get"
}
但是当我运行它时,我明白了:
ValueError: No JSON object could be decoded
到底出了什么问题?昨天它完全像现在一样工作,或者我疯了
我试过这种方式:
from pprint import pprint
import json
import os
for dirname, dirnames, filenames in os.walk('test'):
for filename in filenames:
json_file_contents = open(os.path.join(dirname, filename)).read()
try:
json_data = json.loads(json_file_contents)
except ValueError, e:
print e
print "ERROR"
我看不到任何错误' - '
for filename in filenames:
with open(os.path.join(dirname,filename)) as fd:
json_data = fd.read()
print json_data
通过这种方式,我可以看到json文件包含的内容,但我不能使用密钥进行访问,例如json_data['url']
答案 0 :(得分:6)
.read()
方法可能将光标移动到文件末尾。尝试:
for filename in filenames:
with open(os.path.join(dirname,filename)) as fd:
json_data = json.load(fd)
并查看它的位置。
当然,这可以假设您有valid JSON,正如您的示例所示。 (留意尾随逗号)
答案 1 :(得分:3)
我通过将json文件转换为没有BOM的UTF-8解决了这个错误。 下面是一个python代码段,url用于转换
.....
.....
$.ajax({
headers: {'Authorization': 'Bearer '+tok},
......
......
答案 2 :(得分:0)
我今天遇到了同样的问题。为了解原因,我发现这个问题与json
模块有关:
http://bugs.python.org/issue18958
检查文件是否为UTF8编码,如果是这种情况,则使用codecs
模块打开并读取它,或者只跳过BOM(字节顺序标记)。
答案 3 :(得分:0)
回复表明.read()正在移动光标导致解决了我的问题版本。 我改变了
print response.read()
...
json_data = json.loads(response.read())
到
responseStr = response.read()
print responseStr
...
json_data = json.loads(responseStr)
答案 4 :(得分:0)
尝试在ajax / $ http中使用JSON数据
contentType:“ application / json; charset = utf-8”