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

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

新規登録して質問してみよう
ただいま回答率
85.48%
AWS Lambda

AWS Lambdaは、クラウド上でアプリを実行できるコンピューティングサービス。サーバーのプロビジョニングや管理を要せず複数のイベントに対してコードを実行します。カスタムロジック用いた他AWSサービスの拡張やAWSの規模やパフォーマンスを用いたバックエンドサービスを作成できます。

Amazon DynamoDB

Amazon DynamoDBは、 AWS上のNoSQLデータベースサービスです。フルマネージド型のサービスで、スキーマレス、高速且つ安定性のある動作、自動的に容量を変更する自動スケーリングなどの特徴を持ちます。

JSON

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

解決済

1回答

3603閲覧

dynamodbのputItemができない

pokemonta

総合スコア170

AWS Lambda

AWS Lambdaは、クラウド上でアプリを実行できるコンピューティングサービス。サーバーのプロビジョニングや管理を要せず複数のイベントに対してコードを実行します。カスタムロジック用いた他AWSサービスの拡張やAWSの規模やパフォーマンスを用いたバックエンドサービスを作成できます。

Amazon DynamoDB

Amazon DynamoDBは、 AWS上のNoSQLデータベースサービスです。フルマネージド型のサービスで、スキーマレス、高速且つ安定性のある動作、自動的に容量を変更する自動スケーリングなどの特徴を持ちます。

JSON

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

0クリップ

投稿2020/09/07 02:18

dynamoDBのテーブルfrend(name,frendname,age)を更新する
Lambdaを開発しています。Lambdaのeventに入ってくるJSONは以下のフォーマットを
想定しております。pythonからの戻り値をdynamodb_client.put_itemの引数に入れて
テーブル更新したいのですが信じられないぐらいエラーが出て困っています。
対応方法をご教示願います。
※.putItemなのでそもそもこのような複数行の更新はできないのでしょうか?

Dictionary entries must contain key/value pairs
invalid syntax (<unknown>, line 25)
Expected "}"
Statements must be separated by newlines or semicolons

json

1{ 2 "items" : [ 3 { 4 "data": "boyfrend", 5 "frendList" : [ 6 { 7 "frendName" : "Tom", 8 "age" : "18" 9 }, 10 { 11 "frendName" : "Takashi", 12 "age" : "18" 13 } 14 ] 15 }, 16 { 17 "data": "girlfrend", 18 "frendList" : [ 19 { 20 "frendName" : "mari", 21 "age" : "18" 22 }, 23 { 24 "frendName" : "yuki", 25 "age" : "18" 26 } 27 ] 28 } 29 ] 30}

python

1def create_put_item(event): 2 return { 3 "TableName": "frend", 4 for item in event["items"]: 5 name = item["data"] 6 for frendL in item["frendList"]: 7 8 "Item": { 9 "name": {"S":name}, 10 "frendname": {"S":frendL["frendName"]}, 11 "age": {"S":frendL["age"]} 12 } 13 }

参考情報

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

putItemだからどうこうではなくて、
dict、list型を宣言している文字列中にロジックを入れて処理しているのでエラーになっています。
参考にされているサイトは全て固定値で宣言しているのでエラーになっていませんが。

そのため固定で宣言できる部分のみ文字列で記述し、
残りはキー値を指定したりappend等で挿入したりする必要があります。
詳しくはpythonのlist、dictの処理方法について調べてみてください。

この結果が正しいかどうかはわかりませんが、
引数のjsonから新しいjsonを作る処理を書いてみました。

python

1import json 2from io import StringIO 3 4sio = '''{ 5 "items" : [ 6 { 7 "data": "boyfrend", 8 "frendList" : [ 9 { 10 "frendName" : "Tom", 11 "age" : "18" 12 }, 13 { 14 "frendName" : "Takashi", 15 "age" : "18" 16 } 17 ] 18 }, 19 { 20 "data": "girlfrend", 21 "frendList" : [ 22 { 23 "frendName" : "mari", 24 "age" : "18" 25 }, 26 { 27 "frendName" : "yuki", 28 "age" : "18" 29 } 30 ] 31 } 32 ] 33}''' 34 35event = json.load(StringIO(sio)) 36 37def create_put_item(event): 38 result = { 39 "TableName": "frend", 40 "Item": [] 41 } 42 for item in event["items"]: 43 name = item["data"] 44 for frendL in item["frendList"]: 45 result["Item"].append({ 46 "name": {"S":name}, 47 "frendname": {"S":frendL["frendName"]}, 48 "age": {"S":frendL["age"]} 49 }) 50 return result 51 52print(json.dumps(create_put_item(event), indent=4)) 53''' 54{ 55 "TableName": "frend", 56 "Item": [ 57 { 58 "name": { 59 "S": "boyfrend" 60 }, 61 "frendname": { 62 "S": "Tom" 63 }, 64 "age": { 65 "S": "18" 66 } 67 }, 68 { 69 "name": { 70 "S": "boyfrend" 71 }, 72 "frendname": { 73 "S": "Takashi" 74 }, 75 "age": { 76 "S": "18" 77 } 78 }, 79 { 80 "name": { 81 "S": "girlfrend" 82 }, 83 "frendname": { 84 "S": "mari" 85 }, 86 "age": { 87 "S": "18" 88 } 89 }, 90 { 91 "name": { 92 "S": "girlfrend" 93 }, 94 "frendname": { 95 "S": "yuki" 96 }, 97 "age": { 98 "S": "18" 99 } 100 } 101 ] 102} 103'''

投稿2020/09/07 03:48

編集2020/09/07 03:51
yureighost

総合スコア2183

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

pokemonta

2020/09/07 05:00

めっちゃ勉強なりました。 ロジックを分けるんですね。発想がなかったです。 ありがとうございました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問