目次
1. dict" >1. dict
1. dict 検索が速いのはなぜですか? ? " >1. dict 検索が速いのはなぜですか? ?
2. 避免key不存在的错误,有两种办法。" >2. 避免key不存在的错误,有两种办法。
2.1. 是通过in判断key是否存在" >2.1. 是通过in判断key是否存在
2.2.  是通过dict提供的get方法,如果key不存在,可以返回None,或者自己指定的value" >2.2.  是通过dict提供的get方法,如果key不存在,可以返回None,或者自己指定的value
3. 和list比较,dict有以下几个特点:" >3. 和list比较,dict有以下几个特点:
二、set" >二、set
set和dict的区别" >set和dict的区别
三、再议不可变对象" >三、再议不可变对象
四、总结" >四、总结
ホームページ バックエンド開発 Python チュートリアル Python プログラミングにおける dict と set の一般的な使用法の一覧表

Python プログラミングにおける dict と set の一般的な使用法の一覧表

Jul 25, 2023 pm 04:52 PM
python set dict

1. dict

Python には辞書サポートが組み込まれています: dict. dict の完全名は Dictionary です. 他の言語ではマップとも呼ばれます.非常に高速な検索速度を備えたキーと値 (キーと値) ストレージ。

例: クラスメートの名前に基づいて対応する成績を検索するとします。リストを使用して実装する場合は、2 つのリストが必要です:

names = ['Michael', 'Bob', 'Tracy']
scores = [95, 75, 85]
ログイン後にコピー

名前を定義します。対応するスコアを見つけるには、まず名前内の対応する位置を見つけてから、スコアから対応するスコアを取得する必要があります。リストが長ければ長いほど、時間がかかります。

dict を使用して実装する場合、必要なのは「名前」と「スコア」の比較テーブルだけであり、名前に基づいて結果を直接検索できます。テーブルがどれほど大きくても、検索速度は非常に遅くなります。

例:

d = {'Michael': 95, 'Bob': 75, 'Tracy': 85}
print(d['Michael'])
ログイン後にコピー

Python プログラミングにおける dict と set の一般的な使用法の一覧表

1. dict 検索が速いのはなぜですか? ?

dict は、辞書の索引テーブル (部首テーブルなど) で単語に対応するページ番号を検索し、そのページに直接移動して単語を見つけることを意味します。どの単語を探している場合でも、この検索速度は非常に速く、辞書のサイズが大きくなっても遅くなりません。

# データを dict に入れる方法は、初期化時に指定するだけでなく、キーによって入れることもできます:

#
d['Adam'] = 67
print(d['Adam'])
ログイン後にコピー

Python プログラミングにおける dict と set の一般的な使用法の一覧表

由于一个key只能对应一个value,所以,多次对一个key放入value,后面的值会把前面的值冲掉:

d['Jack'] = 90
d['Jack'] = 88
print(d['Jack']) #多次对一个key放入value,后面的值会把前面的值冲掉:显示后面修改的值
ログイン後にコピー

Python プログラミングにおける dict と set の一般的な使用法の一覧表

如果key不存在,dict就会报错:

print( d['Thomas'])
ログイン後にコピー

Python プログラミングにおける dict と set の一般的な使用法の一覧表

2. 避免key不存在的错误,有两种办法。

2.1. 是通过in判断key是否存在

print('Thomas' in d)
ログイン後にコピー

Python プログラミングにおける dict と set の一般的な使用法の一覧表

2.2. 是通过dict提供的get方法,如果key不存在,可以返回None,或者自己指定的value

d.get('Thomas')
print(d.get('Thomas', -1))
ログイン後にコピー

Python プログラミングにおける dict と set の一般的な使用法の一覧表

注:

返回None的时候Python的交互式命令行不显示结果。

要删除一个key,用pop(key)方法,对应的value也会从dict中删除:

d.pop('Bob')
print(d)
ログイン後にコピー

Python プログラミングにおける dict と set の一般的な使用法の一覧表

3. 和list比较,dict有以下几个特点:

  1. 查找和插入的速度极快,不会随着key的增加而增加;

  2. 需要占用大量的内存,内存浪费多。而list相反:

  3. 查找和插入的时间随着元素的增加而增加;

  4. 占用空间小,浪费内存很少。所以,dict是用空间来换取时间的一种方法。

二、set

set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。

要创建一个set,需要提供一个list作为输入集合:

s = set([1, 2, 3])
print(s)
ログイン後にコピー

Python プログラミングにおける dict と set の一般的な使用法の一覧表

传入的参数[1, 2, 3]是一个list,而显示的{1, 2, 3}只是告诉这个set内部有1,2,3这3个元素,显示的顺序也不表示set是有序的。。

重复元素在set中自动被过滤:

s = set([1, 1, 2, 2, 3, 3])
print(s)
ログイン後にコピー

Python プログラミングにおける dict と set の一般的な使用法の一覧表

通过add(key)方法可以添加元素到set中,可以重复添加,但不会有效果:

s.add(4)
 s{1, 2, 3, 4}
ログイン後にコピー

Python プログラミングにおける dict と set の一般的な使用法の一覧表

通过remove(key)方法可以删除元素:

s.remove(2)
print(s)
ログイン後にコピー

Python プログラミングにおける dict と set の一般的な使用法の一覧表

set可以看成数学意义上的无序和无重复元素的集合,因此,两个set可以做数学意义上的交集、并集等操作:

s1 = set([1, 2, 3])
s2 = set([2, 3, 4])
print(s1 & s2)


print(s1 | s2)
ログイン後にコピー

Python プログラミングにおける dict と set の一般的な使用法の一覧表

set和dict的区别

仅在于没有存储对应的value,但是,set的原理和dict一样,所以,同样不可以放入可变对象,因为无法判断两个可变对象是否相等,也就无法保证set内部“不会有重复元素”。试试把list放入set,看看是否会报错。


三、再议不可变对象

str是不变对象,而list是可变对象。对于可变对象,比如list,对list进行操作,list内部的内容是会变化的。

例:

a = ['c', 'b', 'a']
a.sort() # a['a', 'b', 'c']
print(a)
ログイン後にコピー

Python プログラミングにおける dict と set の一般的な使用法の一覧表

而对于不可变对象,比如str,对str进行操作呢:

a = 'abc'
b = a.replace('a', 'A')
print(b)
print(a)
ログイン後にコピー

Python プログラミングにおける dict と set の一般的な使用法の一覧表

注:

对于不变对象来说,调用对象自身的任意方法,也不会改变该对象自身的内容。相反,这些方法会创建新的对象并返回,这样,就保证了不可变对象本身永远是不可变的。


四、总结

本文基于Python基础,介绍了如何去使用dict和set, 使用key-value存储结构的dict在Python中非常有用,选择不可变对象作为key很重要,最常用的key是字符串。

以上がPython プログラミングにおける dict と set の一般的な使用法の一覧表の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

PSフェザーリングは、遷移の柔らかさをどのように制御しますか? PSフェザーリングは、遷移の柔らかさをどのように制御しますか? Apr 06, 2025 pm 07:33 PM

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

インストール後にMySQLの使用方法 インストール後にMySQLの使用方法 Apr 08, 2025 am 11:48 AM

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

mysqlは支払う必要がありますか mysqlは支払う必要がありますか Apr 08, 2025 pm 05:36 PM

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

PSフェザーリングをセットアップする方法は? PSフェザーリングをセットアップする方法は? Apr 06, 2025 pm 07:36 PM

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

MySQLインストール後にデータベースのパフォーマンスを最適化する方法 MySQLインストール後にデータベースのパフォーマンスを最適化する方法 Apr 08, 2025 am 11:36 AM

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

高負荷アプリケーションのMySQLパフォーマンスを最適化する方法は? 高負荷アプリケーションのMySQLパフォーマンスを最適化する方法は? Apr 08, 2025 pm 06:03 PM

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

PS Featheringは画質にどのような影響を与えますか? PS Featheringは画質にどのような影響を与えますか? Apr 06, 2025 pm 07:21 PM

PSフェザーリングは、画像の詳細の喪失、色の飽和の減少、およびノイズの増加につながる可能性があります。影響を減らすために、小さな羽の半径を使用し、レイヤーをコピーしてから羽毛をコピーし、羽毛の前後に画質を慎重に比較することをお勧めします。さらに、フェザーリングはすべてのケースに適しておらず、マスクなどのツールが画像エッジの処理に適している場合があります。

MySQLインストールエラーソリューション MySQLインストールエラーソリューション Apr 08, 2025 am 10:48 AM

MySQLのインストールの一般的な理由とソリューションの失敗:1。誤ったユーザー名またはパスワード、またはMySQLサービスが開始されない場合、ユーザー名とパスワードを確認してサービスを開始する必要があります。 2。ポートの競合では、MySQLリスニングポートを変更するか、ポート3306を占めるプログラムを閉じる必要があります。 3.依存関係ライブラリがありません。システムパッケージマネージャーを使用して、必要な依存関係ライブラリをインストールする必要があります。 4.許可が不十分な場合、インストーラーを実行するには、sudoまたは管理者の権利を使用する必要があります。 5.誤った構成ファイルでは、構成が正しいことを確認するには、my.cnf構成ファイルを確認する必要があります。着実に慎重に作業することによってのみ、MySQLをスムーズにインストールできます。

See all articles