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

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

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

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

Python

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

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

Q&A

解決済

1回答

1629閲覧

書籍『退屈なことはPythonにやらせよう』の演習問題(P127,5.6.2)からの質問

XocvOrmaz

総合スコア1

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

Python

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

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

0グッド

0クリップ

投稿2020/05/03 04:19

編集2020/05/03 05:45

#書籍『退屈なことはPythonにやらせよう』の演習問題(P127,5.6.2)からの質問です。(下に原文アリ)

書籍『退屈なことはPythonにやらせよう』の演習問題(P127,5.6.2)からの質問で、エラー(AttributeError: 'NoneType' object has no attribute 'items')の直し方が分からず困っています。

#演習問題は以下です(原文ママ)
ファンタジーゲームの持ち物リスト用にリストから辞書に移す関数ドラゴンに勝って獲得したアイテムを、次のような文字列のリストで表すとします。

dragon_loot = ['金貨', '手裏剣', '金貨', '金貨', 'ルビー']

持ち物リストにアイテムを追加する add_to_inventory(inventory, added_items) という関数を書きなさい。ただし、引数inventoryは、前述のようなプレイヤーの持ち物リストを表し、引数 added_items は dragon_loot のようなリストだとします。関数 add_to_inventory() は、更新した辞書を返すようにしてください。リスト added_items には、同じアイテムが複数回出現しうることに注意しましょう。次のようなコードになると思います。

Python

1def add_to_inventory(inventory, added_items): 2#ここにコードを書きます。 3inv = {'金貨': 42, 'ロープ': 1} 4dragon_loot = ['金貨', '手裏剣', '金貨', '金貨', 'ルビー'] 5inv = add_to_inventory(inv, dragon_loot) 6display_inventory(inv)

前述の display_inventory (※後述)を使えば、次のように表示されるでしょう。

持ち物リスト:
45 金貨
1 ロープ
1 ルビー
1 手裏剣
アイテム総数: 48

#エラーの出ているプログラム
これが私の書いたプログラムです。
原文中の金貨をgold medals, 手裏剣をdirks, ルビーをrubies, ロープをropesと置き換えて書いています。

Python

1def add_to_inventory(inventory, added_items): 2 for added_items in dragon_loot: 3 inventory.setdefault(added_items, 0) 4 inventory[added_items] = inventory[added_items] + 1 5 6def display_inventory(inventory): 7 print('List of My Inventory:') 8 item_total = 0 9 for k, v in inventory.items(): 10 print(str(v) + ' ' + k) 11 item_total = item_total + v 12 print('Item Total: ' + str(item_total)) 13 14dragon_loot = ['gold medals', 'dirks', 'gold medals', 'gold medals', 'rubies'] 15inv = {'gold medals': 42, 'ropes': 1} 16 17inv = add_to_inventory(inv, dragon_loot) 18display_inventory(inv)

これを出力すると、以下のようになってしまいます。

List of My Inventory:
Traceback (most recent call last):
File "C:\Users\ifari\Desktop\python\test#3.py", line 19, in <module>
display_inventory(inv)
File "C:\Users\ifari\Desktop\python\test#3.py", line 10, in display_inventory
for k, v in inventory.items():
AttributeError: 'NoneType' object has no attribute 'items'

※『演習問題は以下です(原文ママ)』で(※後述)とした display_inventory のコードは、プログラム中の

Python

1def display_inventory(inventory): 2 print('List of My Inventory:') 3 item_total = 0 4 for k, v in inventory.items(): 5 print(str(v) + ' ' + k) 6 item_total = item_total + v 7 print('Item Total: ' + str(item_total)) 8 9inv = {'gold medals': 42, 'ropes': 1} 10 11display_inventory(inv)

の部分で、こちらは正常に作動しました。

#別パターンで正常に出力されたプログラム
こちらも私が書いたプログラムで、書籍中で示されていた形とは違うパターンで書いてみたプログラムなのですが、こちらは正常に

持ち物リスト:
45 金貨
1 ロープ
1 ルビー
1 手裏剣
アイテム総数: 48

と出力されました。

Python

1def add_to_inventory(inventory, added_items): 2 for added_items in dragon_loot: 3 inventory.setdefault(added_items, 0) 4 inventory[added_items] = inventory[added_items] + 1 5 print('List of My Inventory:') 6 item_total = 0 7 for k, v in inventory.items(): 8 print(str(v) + ' ' + k) 9 item_total = item_total + v 10 print('Item Total: ' + str(item_total)) 11 12dragon_loot = ['gold medals', 'dirks', 'gold medals', 'gold medals', 'rubies'] 13inv = {'gold medals': 42, 'ropes': 1} 14 15add_to_inventory(inv, dragon_loot)

しかし、書籍中で示されていた形とは違うので、もし書籍中で示されていた形で正しくプログラムされていたらどういったものになるのか、教えていただきたいです。

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

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

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

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

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

y_waiwai

2020/05/03 04:21

このままではコードが読めないので、質問を編集し、<code>ボタンを押し、出てくる’’’の枠の中にコードを貼り付けてください
guest

回答1

0

ベストアンサー

処理の内容は追ってませんが、エラーの原因は問題文より、

>関数 add_to_inventory() は、更新した辞書を返すようにしてください。

原因: add_to_inventory()が戻り値を返していないので、invがNoneになる

python

1inv = add_to_inventory(inv, dragon_loot)

解決策:

add_to_inventory関数の末尾で、inventory辞書を返すとエラーはなくなります。

python

1return inventory

もしくは、辞書を返さないのなら
問題には背きますが、inv = で変数を上書きしないようにする。

python

1# 辞書自体は更新されているので、正常なデータが表示されます。 2 3add_to_inventory(inv, dragon_loot) 4display_inventory(inv)

投稿2020/05/03 04:58

teamikl

総合スコア8760

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

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

XocvOrmaz

2020/05/03 05:49

それで解決しました!! 本当にありがとうございました!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問