「json.dumps」実行時に{},{}と 波括弧の間にカンマを入れたい

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 87

gero

score 1

前提・実現したいこと

Python3にてソースコードに
Excelを読み込んだ際、変数に「json.dumps」を使用してjson形式に変換するときに
[{"id": 10}][{"id": 20}]となります。

[{"id": 10},{"id": 20}]

カンマを{}の間に入れたい場合は、どのように行えばよろしいのでしょうか?

該当のソースコード

ソースコード
import openpyxl
import json

book = openpyxl.load_workbook('ファイルのパス')
sheets = book['Sheet1']
path_w = '書き出すファイルのパス'

for i in range(2,12):
    id = sheets.cell(row=i, column=1).value
    name = sheets.cell(row=i, column=2).value
    status = sheets.cell(row=i, column=3).value
    fruits = {
                        "id": id,
                        "name": name,
                        "status": status        
             }


    with open(path_w, mode='a') as f:
        f.write(json.dumps(fruits, sort_keys=False, ensure_ascii=False,indent=4))

このままの状態で実行結果

{
"id": 1,
"name": name,
"status": status        
}
{
"id": 2,
"name": name,
"status": status        
}

と続きます。

試したこと

fruits = {
"id": id,
"name": name,
"status": status        
},

カンマを加える。
結果:
[
{
"id": 1,
"name": name,
"status": status        
}
]
[
{
"id": 2,
"name": name,
"status": status        
}
]

[] が表示されました。

補足情報(参考サイト)

https://www.tantan-biyori.info/blog/2019/04/pythonjson.html

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • LouiS0616

    2019/09/11 07:01

    Pythonタグ及びPython3.xタグを付けて下さい。

    キャンセル

  • gero

    2019/09/11 23:12

    タグを付け足しました。ご指摘ありがとうございます。

    キャンセル

回答 2

+1

JSON形式を利用するなら、
追記モードを使わず一回でドカンと出力するものなのだと思って下さい。

# ファイル1
for i in range(3):
    with open('file1.json', mode='a') as fout:
        fout.write(json.dumps(i))

# ファイル2
dst = []
for i in range(3):
    dst.append(i)

with open('file2.json', mode='w') as fout:
    fout.write(json.dumps(dst))

実行結果:file1.json

012

実行結果:file2.json

[0, 1, 2]

なぜカンマを付けると角括弧が出現する?

カンマを付けるとPythonの文法上1要素のタプルとして取り扱われます。

>>> a = 42
>>> type(a)
<class 'int'>
>>>
>>> a = 42,
>>> type(a)
<class 'tuple'>
>>> a
(42,)
>>> a[0]
42

JSONは仕様にタプルを持たないので、類似の構造として配列が使われます。
1要素の配列だから角括弧が付いたのです。それだけ。

>>> a = 42,
>>> b = list(a)
>>> b
[42]

『カンマを付けたいから試しにコードに付けてみた』というのはあまりに短絡的です。
基礎から少しずつ実力を身に付けましょう。

公式チュートリアルは、プログラミング初心者にとっては少し取っつき辛いのが難点です。
書店に行ってできるだけ新しい入門書を買ってくるのが無難です。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/09/11 23:14

    いろいろご指摘ありがとうございます。とても勉強になります。

    キャンセル

checkベストアンサー

0

フルーツのリストを作ってからdumpすればいいです。

ソースコード
import openpyxl
import json

book = openpyxl.load_workbook('ファイルのパス')
sheets = book['Sheet1']
path_w = '書き出すファイルのパス'

fruits = []
for i in range(2,12):
    id = sheets.cell(row=i, column=1).value
    name = sheets.cell(row=i, column=2).value
    status = sheets.cell(row=i, column=3).value
    fruit = {"id": id, "name": name, "status": status}
    fruits.append(fruit)

with open(path_w, mode='w') as f:
    f.write(json.dumps(fruits, sort_keys=False, ensure_ascii=False, indent=4))

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/09/11 23:13

    期待通りの結果になりました!
    誠にありがとうございます。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.22%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる