ファイルからJSONを読み取りますか?


320

単純に見える簡単な文が私の顔にいくつかのエラーを投げているからといって、少し頭痛がします。

次のようなstrings.jsonというjsonファイルがあります。

"strings": [{"-name": "city", "#text": "City"}, {"-name": "phone", "#text": "Phone"}, ...,
            {"-name": "address", "#text": "Address"}]

とりあえずjsonファイルを読みたいのですが。私が見つけたこれらのステートメントがありますが、機能していません:

import json
from pprint import pprint

with open('strings.json') as json_data:
    d = json.loads(json_data)
    json_data.close()
    pprint(d)

コンソールに表示されるエラーは次のとおりです。

Traceback (most recent call last):
  File "/home/.../android/values/manipulate_json.py", line 5, in <module>
    d = json.loads(json_data)
  File "/usr/lib/python2.7/json/__init__.py", line 326, in loads
    return _default_decoder.decode(s)
  File "/usr/lib/python2.7/json/decoder.py", line 366, in decode
    obj, end = self.raw_decode(s, idx=_w(s, 0).end())
TypeError: expected string or buffer
[Finished in 0.1s with exit code 1]

編集済み

からjson.loadsに変更されましたjson.load

そしてこれを得た:

Traceback (most recent call last):
  File "/home/.../android/values/manipulate_json.py", line 5, in <module>
    d = json.load(json_data)
  File "/usr/lib/python2.7/json/__init__.py", line 278, in load
    **kw)
  File "/usr/lib/python2.7/json/__init__.py", line 326, in loads
    return _default_decoder.decode(s)
  File "/usr/lib/python2.7/json/decoder.py", line 369, in decode
    raise ValueError(errmsg("Extra data", s, end, len(s)))
ValueError: Extra data: line 829 column 1 - line 829 column 2 (char 18476 - 18477)
[Finished in 0.1s with exit code 1]

6
ファイルに有効なJSONが含まれていますか?
爆発の丸薬2013年



ファイルは無効なjson形式です。それを変更します {"strings": [{"-name": "city", "#text": "City"}, {"-name": "phone", "#text": "Phone"}, ..., {"-name": "address", "#text": "Address"}]}
krizex

回答:


546

json.load()方法(「負荷」の「S」なし)は、ファイルを直接読み取ることができます。

import json

with open('strings.json') as f:
    d = json.load(f)
    print(d)

あなたは使用していたjson.loads()方法のために使用され、文字列の引数のみを。

編集:新しいメッセージはまったく別の問題です。その場合、そのファイルには無効なjsonが含まれています。そのため、jsonバリデーターを介してファイルを実行することをお勧めします。

たとえば、無効なJSON文字列を自動的に修正する方法など、jsonを修正するためのソリューションもあります。


2
hm ... json.loadsからjson.loadに変更しましたが、メッセージが表示されます。
RRC 2013年

5
ああ、まあ、新しいメッセージはまったく別の問題です。その場合、そのファイルには無効なjsonが含まれています。そのため、jsonバリデーターを介してファイルを実行することをお勧めします。
ubomb 2013年

3
とった!ファイルにEOFがありませんでした。ファイルが正しく終了していません。それがあなたの良い推薦でなかったなら、私は気づかないでしょう!ありがとう!
RRC 2013年

1
ubomb、変更できる場合は、私に回答して、承認済みとしてマークしてください。自由になれ!マークします。
RRC 2013年

バイトフラグでファイルを開く必要があるので、json.loadメソッドを使用できます。なぜですか?Py3.6を取得しました
Grzegorz Krug

113

これは私にとってうまく機能するコードのコピーです

import json

with open("test.json") as json_file:
    json_data = json.load(json_file)
    print(json_data)

データとともに

{
    "a": [1,3,"asdf",true],
    "b": {
        "Hello": "world"
    }
}

無効なJSONがスタックトレースエラーメッセージを引き起こすため、json.load行をtryキャッチでラップすることをお勧めします。


41

問題はwithステートメントを使用しています:

with open('strings.json') as json_data:
    d = json.load(json_data)
    pprint(d)

ファイルはすでに暗黙的に閉じられます。json_data.close()再度電話する必要はありません。


1
json_data.close()を削除してください。前述のように、暗黙的に呼び出されます。
Bonnie Varghese 14年

1
@Zongjun:json.load(json_data)へのロードを修正してください。
Knight71、15年

2
きれいに印刷するために、私は使用しなければなりませんでした:print(json.dumps(d,sort_keys=True,indent=2))
Mike D

25

Python 3では、以下のメソッドを使用できます。

ファイルから読み取り、JSONに変換する

import json
from pprint import pprint

# Considering "json_list.json" is a json file

with open('json_list.json') as fd:
     json_data = json.load(fd)
     pprint(json_data)

withステートメントは、開いているファイル記述子を自動的に閉じます。


JSONへの文字列

import json
from pprint import pprint

json_data = json.loads('{"name" : "myName", "age":24}')
pprint(json_data)

3

これを追加するには、今日、pandasを使用してjsonをインポートすることができます:
https : //pandas.pydata.org/pandas-docs/stable/generated/pandas.read_json.htmlパラメータ。


あなたはコード例と同様にURLを追加する場合は、この答えは...良いだろう
デヴィッドMcCorrie

1

パンダライブラリを使用してJSONファイルを読み取ることができます。

import pandas as pd
df = pd.read_json('strings.json',lines=True)
print(df)

0

これは私にとってはうまくいきます。

json.load()はファイルオブジェクトを受け取り、JSONデータを解析し、Pythonディクショナリにデータを入力して返します。

JSONファイルが次のようであるとします。

{
   "emp_details":[
                 {
                "emp_name":"John",
                "emp_emailId":"john@gmail.com"  
                  },
                {
                 "emp_name":"Aditya",
                 "emp_emailId":"adityatest@yahoo.com"
                }
              ] 
}

import json 

# Opening JSON file 
f = open('data.json',) 

# returns JSON object as  
# a dictionary 
data = json.load(f) 

# Iterating through the json 
# list 
for i in data['emp_details']: 
    print(i) 

# Closing file 
f.close()

#Output:
{'emp_name':'John','emp_emailId':'john@gmail.com'}
{'emp_name':'Aditya','emp_emailId':'adityatest@yahoo.com'}
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.