質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
87.20%
JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

解決済

pythonでjsonの追記がしたい

tuyioj
tuyioj

総合スコア13

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

1回答

0評価

0クリップ

114閲覧

投稿2022/07/04 05:12

追記したい大本のJSON

JSON

{ "name": "test1", "responses": [ { "action": "test1", "parameters": [ {"name": "関数1","dataType": "@関数","value": "$関数1"}, 追加したい項目1 {"name": "関数2","dataType": "@関数","value": "$関数2"} ], "messages": [ {"type": "message","condition": "","speech": ["$関数1説明"]} , 追加したい項目2 {"type": "message","condition": "","speech": ["$関数2説明"]} ], "resetContexts": "false" } ], "userSays": [ { "isTemplate": "false", "data": [ {"text": "内容","alias": "関数1","meta": "@関数"},{"text": "内容"}, 追加したい項目3 {"text": "内容","alias": "関数2","meta": "@関数"},{"text": "内容"} ], "count": 0, "updated": "null" } ], "webhookForSlotFilling": "false", "webhookUsed": "false" }

コード

python

import pandas as pd data = pd.read_csv('/content/test.csv').values.tolist() name=[] message=[] alias=[] for i in range(len(data)): name.append('{"name": "関数'+str(i)+'","dataType": "@関数","value": "$関数'+str(i)+'"}'); message.append('{"type": "message","condition": '',"speech": ["$関数'+str(i)+'は'+input(f"{data[i]}説明を入力")+'です"]}'); alias.append('{"text": "'+input(f"{data[i]}の内容を入力")+'","alias": "関数'+str(i)+'","meta": "@関数"},{"text": "内容"}'); name_json= ','.join(name) message_json= ','.join(message) alias_json= ','.join(alias) json_data={"name": "test1","responses": [{"action": "test1","parameters": [name_json],"messages": [message_json],"resetContexts": "false"}],"userSays": [{"isTemplate": "false","data": [alias_json],"count": 0,"updated": "null"}],"webhookForSlotFilling": "false","webhookUsed": "false"} import json with open('mydata.json', mode='wt', encoding='utf-8') as file: json.dump(json_data, file, ensure_ascii=False, indent=2)

名前の入ったcsvファイルを読み込んで
追加したい要素ごとに配列を作って
appendで追加をしたあと
各配列の各要素の間にカンマを入れた文字列にして
jsonの大枠にいれて
jsonファイルで書き出し

そんなかんじのことをしているんですが
書き出されたファイルが

JSON

{ "name": "test1", "responses": [ { "action": "test1", "parameters": [ "{\"name\": \"関数0\",\"dataType\": \"@関数\",\"value\": \"$関数0\"},{\"name\": 略 alue\": \"$関数14\"}" ], "messages": [ "{\"type\": \"message\",\"condition\": ,\"speech\": [\"$関数0は〇〇です\"]},{\"type\":  略 ech\": [\"$関数14は〇〇です\"]}" ], "resetContexts": "false" } ], "userSays": [ { "isTemplate": "false", "data": [ "{\"text\": \"内容前\",\"alias\": \"関数0\",\"meta\": \"@関数\"},{\"text\": \"内容後ろ\"},{\"text\": \ 略 e\"},{\"text\": \"内容後ろ\"}" ], "count": 0, "updated": "null" } ], "webhookForSlotFilling": "false", "webhookUsed": "false" }

およそ思ったような形にはなったのですが ”が正規表現化?してしまって使える形になっていなくてpythonでjsonの追加をしたちと起動したら良いのでしょうか?

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。