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

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

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

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

Amazon DynamoDB

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Python

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

Q&A

解決済

2回答

1367閲覧

pythonのエラー処理がわかりません。

pokemonta

総合スコア170

AWS Lambda

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

Amazon DynamoDB

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Python

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

0グッド

0クリップ

投稿2020/11/25 01:04

forループを使って、順番に名前(taisho)が渡れて
それを使ってDBから属性情報を抽出するpythonプログラムがあります。

DBから、対象データがなかった場合、
return response['Item']でunboundlocalerrorが発生しますので
get_ageでtry~exceptでキャッチしているため
現行の結果では、name:yoshidaが表示されません。
あるべき姿にするにはどのようにすべきでしょうか?

そもそもDBから、対象データがなかった場合
ハンドリングとしてこのような処理はダサくないでしょうか?

taisho

1'tanaka','watanabe','yoshida'

python

1def get_age(name): 2 3 dynamodb = boto3.resource('dynamodb') 4 table = dynamodb.Table('sample1') 5 response = table.get_item( 6 Key={ 7 'name': name 8 } 9 ) 10 return response['Item'] 11///////////////////  /////////////////// 12///////////////////省略/////////////////// 13///////////////////  /////////////////// 14 15 for name in taisho: 16 try: 17 result = get_age(name) 18 except UnboundLocalError as ex: 19 continue 20 21 if result is not None: 22 dict = { 23 'name' : name, 24 'value' : result['age'] 25 } 26 List.append(dict)

現行:continueでDBにないデータはスキップ

List

1{name:tanaka,age:22},{name:watanabe,age:12}

あるべき姿:DBにないデータもageをブランクで表示したい

List

1{name:tanaka,age:22},{name:watanabe,age:12},{name:yoshida,age:}

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

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

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

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

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

plasticgrammer

2020/11/25 06:15

> あるべき姿:DBにないデータもageをブランクで表示したい 連想配列でキーがあって値がない状態は作れないかと思います。 0長文字列('')やNoneとするのが適切だと考えますが、いかがでしょうか。
pokemonta

2020/12/17 05:16

0長文字列('')で表示できれば良いと思います。
guest

回答2

0

ベストアンサー

{name:yoshida,age:}というのは、pythonのリテラルにはありませんので無理です。
{name:yoshida,age:'not available'}などとすることは以下のコードで可能です。
'not available'を''にしたほうがご希望に近いかもしれません。

下から3行目の'value'を'age'に変えましたが、必要なら'value'に戻してください。

python

1def get_age(name): 2 3 dynamodb = boto3.resource('dynamodb') 4 table = dynamodb.Table('sample1') 5 response = table.get_item( 6 Key={ 7 'name': name 8 } 9 ) 10 return response['Item']['age'] 11///////////////////  /////////////////// 12///////////////////省略/////////////////// 13///////////////////  /////////////////// 14 15 for name in taisho: 16 try: 17 result = get_age(name) 18 except UnboundLocalError as ex: 19 result = 'not available' 20 21 dict = { 22 'name' : name, 23 'age' : result['age'] 24 } 25 List.append(dict)

投稿2020/11/30 15:00

編集2020/11/30 15:01
ppaul

総合スコア24670

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

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

0

上手くいくかは検証できていませんが、以下のコードでどうでしょうか。

  • in によりItemがあるか判定しています
  • 該当データなしでageをNoneとしています。

python

1def get_age(name): 2 3 dynamodb = boto3.resource('dynamodb') 4 table = dynamodb.Table('sample1') 5 response = table.get_item( 6 Key={ 7 'name': name 8 } 9 ) 10 if 'Item' in response: 11 return response['Item']['age'] 12 else: 13 return None 14///////////////////  /////////////////// 15///////////////////省略/////////////////// 16///////////////////  /////////////////// 17 18 for name in taisho: 19 20 if result is not None: 21 dict = { 22 'name' : name, 23 'value' : get_age(name) 24 } 25 List.append(dict)

投稿2020/11/25 06:21

plasticgrammer

総合スコア629

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問