Python で TypeError:unhashable type:'dict' エラーを解決する方法
Python "TypeError: unhashable type: ‘dict’ " は、辞書を別の辞書のキーまたはコレクションの要素として使用するときに発生します。
このエラーを解決するには、代わりに frozenset
を使用するか、キーとして使用する前に辞書を JSON 文字列に変換する必要があります。
ある辞書を別の辞書のキーとして使用すると、エラーが発生します。
# ????️ using dictionary as a key in a dictionary # ⛔️ TypeError: unhashable type: 'dict' my_dict = {'name': 'Jiyik', {'country': 'China'}: 'address'}
または、set
オブジェクトの要素として辞書を使用する場合。
# ????️ 使用字典作为集合中的元素 # ⛔️ TypeError: unhashable type: 'dict' my_set = {{'name': 'Jiyik'}}
辞書オブジェクトは変更可能でハッシュ不可能であるため、辞書を辞書内のキーまたはコレクション内の要素として使用することはできません。
辞書を JSON 文字列に変換してエラーを解決します。
このエラーを解決する 1 つの方法は、辞書をキーとして使用する前に JSON 文字列に変換することです。
import json # ????️ 将字典转换为 JSON 字符串 my_json = json.dumps({'country': 'China'}) my_dict = {'name': 'Jiyik', my_json: 'address'} print(my_dict) # ????️ {'name': 'Jiyik', '{"country": "China"}': 'address'} # ????️ 当你必须访问字典中的键时 print(my_dict[json.dumps({'country': 'Austria'})]) # ????️ address
json.dumps
メソッドは、Python オブジェクトを JSON 形式の文字列に変換します。これが機能するのは、文字列が不変でハッシュ可能であるためです。
対照的に、json.loads
メソッドは、my_dict = json.loads(my_json_str)
など、JSON 文字列をネイティブ Python オブジェクトに解析します。
frozenset を使用したエラー解決
エラーを解決するもう 1 つの方法は、frozenset
を使用することです。
my_key = {'country': 'China'} key = frozenset(my_key.items()) print(key) # ????️ frozenset({('country', 'China')}) my_dict = {'name': 'Jiyik', key: 'address'} # ????️ 当我们必须访问 key 时 print(my_dict[frozenset(my_key.items())]) # ????️ 'address'
dict.items
メソッドは、辞書項目 ((キー、値) ペア) の新しいビューを返します。
# ????️ dict_items([('name', 'jiyik'), ('age', 30)]) print({'name': 'jiyik', 'age': 30}.items())
辞書の項目を使用して、辞書内のキー (および別のセットの要素) として使用できる frozenset
を作成します。
frozenset
は Python コレクション オブジェクトの不変バージョンであるため、辞書内のキーとして、または別のコレクション内の要素として使用できます。
辞書内のキーにアクセスするには、同じメソッドを使用する必要があることに注意してください。
frozenset(my_key.items()) を呼び出した結果を変数に保存し、ディクショナリ内のキーを設定またはアクセスするときにフローズンセットを再利用できます。
dict_key = {'id': 1, 'country': 'China'} # ✅ 转换为元组 my_tuple = tuple(dict_key) print(my_tuple) # ????️ ('id', 'country') my_dict = {'name': 'Jiyik', my_tuple: 'address'} print(my_dict) # ????️ {'name': 'Jiyik', ('id', 'country'): 'address'} # ????️ 当你必须访问字典中的键时 print(my_dict[my_tuple]) # ????️ address
dict_value = {'id': 1, 'country': 'China'} my_dict = {'name': 'Jiyik', 'data': dict_value} # ????️ {'name': 'Jiyik', 'data': {'id': 1, 'country': 'China'}} print(my_dict) print(my_dict['data']) # ????️ {'id': 1, 'country': 'China'}
another_dict = {'id': 1, 'country': 'China'} my_dict = {'name': 'Jiyik'} for key, value in another_dict.items(): my_dict[key] = value # ????️ {'name': 'Jiyik', 'id': 1, 'country': 'China'} print(my_dict)
dict.items メソッドは、辞書項目 ((キー、値) ペア) の新しいビューを返します。
my_dict = {'id': 1, 'name': 'Jiyik'} # ????️ dict_items([('id', 1), ('name', 'Jiyik')]) print(my_dict.items())
オブジェクトがハッシュ可能である場合、これらのデータ構造は内部でハッシュ値を使用するため、オブジェクトを辞書のキーおよびコレクションの要素として使用できます。ハッシュ可能なオブジェクトには、
str、int、bool、tuple、frozenset#が含まれます。 ##。 ハッシュ化できないオブジェクトには、
list、dict、set が含まれます。
hash()タプルと凍結セットは、その要素がハッシュ可能である場合にのみハッシュ可能であることに注意してください。
オブジェクトが組み込みのオブジェクトがハッシュ可能かどうかの確認
関数に渡すことで、オブジェクトがハッシュ可能かどうかを確認できます。
print(hash('jiyik.com')) # ????️ 4905958875846995527 # ⛔️ TypeError: unhashable type: 'dict' print(hash({'name': 'Jiyik'}))
ハッシュ値は、辞書検索中に辞書キーを比較するために使用される整数です。
!> ハッシュ可能オブジェクトのハッシュ値は、その存続期間中は決して変更されません。これが、ほとんどの不変オブジェクトがハッシュ可能であるのに対し、可変オブジェクトはハッシュ可能ではない理由です。
辞書のようなオブジェクトは、辞書の内容が変更される可能性があるため、変更可能です。
my_dict = {'name': 'Fql'} my_dict['name'] = 'Jiyik' print(my_dict) # ????️ {'name': 'Jiyik'}
一方、
fronzensetとプリミティブ値を含むタプル オブジェクトは不変 (およびハッシュ可能) です。
辞書はキーによってインデックス付けされます。キーには文字列や数値などの不変型を使用できます。
fronzenset
またはタプルに変更可能なオブジェクト (リストなど) が含まれている場合、それを辞書内のキーまたはセット内の要素として使用することはできません。
変数に格納されるオブジェクトのタイプが不明な場合は、type()
関数を使用してください。
my_dict = {'name': 'Jiyik'} print(type(my_dict)) # ????️ <class 'dict'> print(isinstance(my_dict, dict)) # ????️ True my_str = 'jiyik.com' print(type(my_str)) # ????️ <class 'str'> print(isinstance(my_str, str)) # ????️ True
type
この関数はオブジェクトのタイプを返します。
渡されたオブジェクトが渡されたクラスのインスタンスまたはサブクラスの場合、isinstance
関数は True を返します。
以上がPython で TypeError:unhashable type:'dict' エラーを解決する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









MySQLには、無料のコミュニティバージョンと有料エンタープライズバージョンがあります。コミュニティバージョンは無料で使用および変更できますが、サポートは制限されており、安定性要件が低く、技術的な能力が強いアプリケーションに適しています。 Enterprise Editionは、安定した信頼性の高い高性能データベースを必要とするアプリケーションに対する包括的な商業サポートを提供し、サポートの支払いを喜んでいます。バージョンを選択する際に考慮される要因には、アプリケーションの重要性、予算編成、技術スキルが含まれます。完璧なオプションはなく、最も適切なオプションのみであり、特定の状況に応じて慎重に選択する必要があります。

羽毛の鍵は、その漸進的な性質を理解することです。 PS自体は、勾配曲線を直接制御するオプションを提供しませんが、複数の羽毛、マッチングマスク、および細かい選択により、半径と勾配の柔らかさを柔軟に調整して、自然な遷移効果を実現できます。

この記事では、MySQLデータベースの操作を紹介します。まず、MySQLWorkBenchやコマンドラインクライアントなど、MySQLクライアントをインストールする必要があります。 1. mysql-uroot-pコマンドを使用してサーバーに接続し、ルートアカウントパスワードでログインします。 2。CreatedAtaBaseを使用してデータベースを作成し、データベースを選択します。 3. createTableを使用してテーブルを作成し、フィールドとデータ型を定義します。 4. INSERTINTOを使用してデータを挿入し、データをクエリし、更新することでデータを更新し、削除してデータを削除します。これらの手順を習得することによってのみ、一般的な問題に対処することを学び、データベースのパフォーマンスを最適化することでMySQLを効率的に使用できます。

PSフェザーリングは、イメージエッジブラー効果であり、エッジエリアのピクセルの加重平均によって達成されます。羽の半径を設定すると、ぼやけの程度を制御でき、値が大きいほどぼやけます。半径の柔軟な調整は、画像とニーズに応じて効果を最適化できます。たとえば、キャラクターの写真を処理する際に詳細を維持するためにより小さな半径を使用し、より大きな半径を使用してアートを処理するときにかすんだ感覚を作成します。ただし、半径が大きすぎるとエッジの詳細を簡単に失う可能性があり、効果が小さすぎると明らかになりません。羽毛効果は画像解像度の影響を受け、画像の理解と効果の把握に従って調整する必要があります。

mysqlダウンロードファイルは破損していますが、どうすればよいですか?残念ながら、MySQLをダウンロードすると、ファイルの破損に遭遇できます。最近は本当に簡単ではありません!この記事では、誰もが迂回を避けることができるように、この問題を解決する方法について説明します。それを読んだ後、損傷したMySQLインストールパッケージを修復するだけでなく、将来の行き詰まりを避けるために、ダウンロードとインストールプロセスをより深く理解することもできます。最初に、ファイルのダウンロードが破損した理由について話しましょう。これには多くの理由があります。ネットワークの問題は犯人です。ダウンロードプロセスの中断とネットワーク内の不安定性は、ファイル腐敗につながる可能性があります。ダウンロードソース自体にも問題があります。サーバーファイル自体が壊れており、もちろんダウンロードすると壊れています。さらに、いくつかのウイルス対策ソフトウェアの過度の「情熱的な」スキャンもファイルの破損を引き起こす可能性があります。診断問題:ファイルが本当に破損しているかどうかを判断します

MySQLのインストール障害の主な理由は次のとおりです。1。許可の問題、管理者として実行するか、SUDOコマンドを使用する必要があります。 2。依存関係が欠落しており、関連する開発パッケージをインストールする必要があります。 3.ポート競合では、ポート3306を占めるプログラムを閉じるか、構成ファイルを変更する必要があります。 4.インストールパッケージが破損しているため、整合性をダウンロードして検証する必要があります。 5.環境変数は誤って構成されており、環境変数はオペレーティングシステムに従って正しく構成する必要があります。これらの問題を解決し、各ステップを慎重に確認して、MySQLを正常にインストールします。

MySQLパフォーマンスの最適化は、インストール構成、インデックス作成、クエリの最適化、監視、チューニングの3つの側面から開始する必要があります。 1。インストール後、INNODB_BUFFER_POOL_SIZEパラメーターやclose query_cache_sizeなど、サーバーの構成に従ってmy.cnfファイルを調整する必要があります。 2。過度のインデックスを回避するための適切なインデックスを作成し、説明コマンドを使用して実行計画を分析するなど、クエリステートメントを最適化します。 3. MySQL独自の監視ツール(ShowProcessList、ShowStatus)を使用して、データベースの健康を監視し、定期的にデータベースをバックアップして整理します。これらの手順を継続的に最適化することによってのみ、MySQLデータベースのパフォーマンスを改善できます。

MySQLデータベースパフォーマンス最適化ガイドリソース集約型アプリケーションでは、MySQLデータベースが重要な役割を果たし、大規模なトランザクションの管理を担当しています。ただし、アプリケーションのスケールが拡大すると、データベースパフォーマンスのボトルネックが制約になることがよくあります。この記事では、一連の効果的なMySQLパフォーマンス最適化戦略を検討して、アプリケーションが高負荷の下で効率的で応答性の高いままであることを保証します。実際のケースを組み合わせて、インデックス作成、クエリ最適化、データベース設計、キャッシュなどの詳細な主要なテクノロジーを説明します。 1.データベースアーキテクチャの設計と最適化されたデータベースアーキテクチャは、MySQLパフォーマンスの最適化の基礎です。いくつかのコア原則は次のとおりです。適切なデータ型を選択し、ニーズを満たす最小のデータ型を選択すると、ストレージスペースを節約するだけでなく、データ処理速度を向上させることもできます。
