Python 2.7以降で次のようなものを作成する方法はありますか?
{ something_if_true if condition else something_if_false for key, value in dict_.items() }
私はあなたが'if'だけで何でも作ることができることを知っています:
{ something_if_true for key, value in dict_.items() if condition}
Python 2.7以降で次のようなものを作成する方法はありますか?
{ something_if_true if condition else something_if_false for key, value in dict_.items() }
私はあなたが'if'だけで何でも作ることができることを知っています:
{ something_if_true for key, value in dict_.items() if condition}
あなたはすでにそれを持っています:A if test else B
は有効なPython式です。示されているように、dict理解に関する唯一の問題は、dict理解内の式の場所には、コロンで区切られた2つの式が必要であるということです。
{ (some_key if condition else default_key):(something_if_true if condition
else something_if_false) for key, value in dict_.items() }
最後のif
句は、条件式を持つのとは異なるフィルターとして機能します。
@Marcinの答えはすべてを網羅していますが、誰かが実際の例を見たい場合に備えて、以下に2つ追加します。
次のセットの辞書があるとしましょう
d = {'key1': {'a', 'b', 'c'}, 'key2': {'foo', 'bar'}, 'key3': {'so', 'sad'}}
'a'
文字列が値に含まれているかどうかをキーが示す新しい辞書を作成する場合は、次を使用できます。
dout = {"a_in_values_of_{}".format(k) if 'a' in v else "a_not_in_values_of_{}".format(k): v for k, v in d.items()}
これは
{'a_in_values_of_key1': {'a', 'b', 'c'},
'a_not_in_values_of_key2': {'bar', 'foo'},
'a_not_in_values_of_key3': {'sad', 'so'}}
ここで、このような2つの辞書があるとします。
d1 = {'bad_key1': {'a', 'b', 'c'}, 'bad_key2': {'foo', 'bar'}, 'bad_key3': {'so', 'sad'}}
d2 = {'good_key1': {'foo', 'bar', 'xyz'}, 'good_key2': {'a', 'b', 'c'}}
そして、それぞれの値が同一である場合d1
のキーでキーを置き換えたい場合は、次のようにすることができます。d2
# here we assume that the values in d2 are unique
# Python 2
dout2 = {d2.keys()[d2.values().index(v1)] if v1 in d2.values() else k1: v1 for k1, v1 in d1.items()}
# Python 3
dout2 = {list(d2.keys())[list(d2.values()).index(v1)] if v1 in d2.values() else k1: v1 for k1, v1 in d1.items()}
これは
{'bad_key2': {'bar', 'foo'},
'bad_key3': {'sad', 'so'},
'good_key2': {'a', 'b', 'c'}}
キーと値を評価するためのさまざまな条件がある場合は、@Marcinの答えが最適です。
キーと値に同じ条件がある場合は、(キー、値)-ジェネレーター式のタプルを次のようにフィードすることをお勧めしますdict()
。
dict((modify_k(k), modify_v(v)) if condition else (k, v) for k, v in dct.items())
読みやすく、条件はキー、値ごとに1回だけ評価されます。
@Clebのセットの辞書を借用した例:
d = {'key1': {'a', 'b', 'c'}, 'key2': {'foo', 'bar'}, 'key3': {'so', 'sad'}}
その中でのみ接尾辞を付けたいと仮定keys
しa
、そのような場合にセットの長さに置き換えvalue
たいと仮定します。value
それ以外の場合、キーと値のペアは変更されないままである必要があります。
dict((f"{k}_a", len(v)) if "a" in v else (k, v) for k, v in d.items())
# {'key1_a': 3, 'key2': {'bar', 'foo'}, 'key3': {'sad', 'so'}}
Ifステートメントだけが最後にifを置くことも言及する価値があるかもしれません:
{_ for _ in iterable if True}
辞書理解でif/elseを使用する別の例
私は自分の事務用のデータ入力デスクトップアプリケーションに取り組んでいます。このようなデータ入力アプリケーションは、入力ウィジェットからすべてのエントリを取得し、検証や編集などのさらなる処理のために辞書にダンプするのが一般的です。ファイルからエントリウィジェットなどに戻る選択されたデータ。
従来のコーディングを使用した最初のラウンド(8行):
entries = {'name': 'Material Name', 'maxt': 'Max Working Temperature', 'ther': {100: 1.1, 200: 1.2}}
a_dic, b_dic = {}, {}
for field, value in entries.items():
if field == 'ther':
for k,v in value.items():
b_dic[k] = v
a_dic[field] = b_dic
else:
a_dic[field] = value
print(a_dic)
“ {'name': 'Material Name', 'maxt': 'Max Working Temperature', 'ther': {100: 1.1, 200: 1.2}}”
第2ラウンド私は辞書理解を使おうとしましたが、ループはまだそこにあります(6行):
entries = {'name': 'Material Name', 'maxt': 'Max Working Temperature', 'ther': {100: 1.1, 200: 1.2}}
for field, value in entries.items():
if field == 'ther':
b_dic = {k:v for k,v in value.items()}
a_dic[field] = b_dic
else:
a_dic[field] = value
print(a_dic)
“ {'name': 'Material Name', 'maxt': 'Max Working Temperature', 'ther': {100: 1.1, 200: 1.2}}”
最後に、1行の辞書理解ステートメント(1行)を使用します。
entries = {'name': 'Material Name', 'maxt': 'Max Working Temperature', 'ther': {100: 1.1, 200: 1.2}}
a_dic = {field:{k:v for k,v in value.items()} if field == 'ther'
else value for field, value in entries.items()}
print(a_dic)
“ {'name': 'Material Name', 'maxt': 'Max Working Temperature', 'ther': {100: 1.1, 200: 1.2}}”
私はPython3.8.3を使用しています