国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

ホームページ バックエンド開発 Python チュートリアル 効率的で読みやすい Python コードを作成するための強(qiáng)力なテクニック

効率的で読みやすい Python コードを作成するための強(qiáng)力なテクニック

Oct 31, 2024 pm 07:06 PM

Powerful Techniques for Writing Efficient and Readable Python Code

Python はそのシンプルさと多用途性で知られていますが、経験豊富な開発者であっても、パフォーマンスと可読性を最大化するベスト プラクティスを採用することで恩恵を受けることができます。データ サイエンス、機(jī)械學(xué)習(xí)、Python による Web 開発の臺頭により、今日の急速に変化するテクノロジー環(huán)境で競爭力を維持するには、効率的なコード テクニックを習(xí)得することが必須となっています。ここでは、複雑なプロジェクトに取り組んでいる場合でも、簡単な自動化スクリプトに取り組んでいる場合でも、Python コードのパフォーマンスと読みやすさを向上させるための 20 の効果的なテクニックを詳しく説明します。

1.ジェネレーターを使用してメモリを節(jié)約

ジェネレーターは、過剰なメモリを使用せずに大規(guī)模なデータセットを処理するのに最適です。すべてをメモリに保持するのではなく、一度に 1 つずつデータを生成します。たとえば、ジェネレーターを使用すると、大きなログ ファイルを 1 行ずつ読み取ることができます。

def read_large_file(file_path):
    with open(file_path, 'r') as file:
        for line in file:
            yield line.strip()

このアプローチは、限られたメモリでの作業(yè)が不可欠なデータ処理やバッチ トレーニングなどのタスクに特に役立ちます。

2. .setdefault() でデフォルト値を設(shè)定する

辭書內(nèi)のキーをデフォルト値で初期化する必要がある場合、.setdefault() を使用すると手動チェックを省略できます。

inventory = {"jeans": 500, "top": 600}
inventory.setdefault("shoes", 0)
print(inventory)

これにより、デフォルト値の管理がより簡潔になり、余分な if ステートメントが不要になります。

3. if-elif チェーンを辭書に置き換えます

長い if-elif チェーンの代わりに辭書を使用して関數(shù)をマップすると、コードがよりクリーンになり、保守しやすくなります。

def start(): print("Start")
def stop(): print("Stop")
actions = {"start": start, "stop": stop}
action = "start"
actions.get(action, lambda: print("Invalid"))()

この構(gòu)造により、特に大規(guī)模なデシジョン ツリーでの読みやすさとパフォーマンスが向上します。

4. Counter を使用してカウントを簡素化します

コレクション モジュールの Counter クラスは、頻度分析など、Python でのカウント タスクを簡素化する優(yōu)れた方法です。

from collections import Counter
words = ["apple", "banana", "apple", "orange", "banana"]
counts = Counter(words)
print(counts)

カスタムのカウント関數(shù)を作成する必要がなくなり、効率的かつ使いやすくなります。

5.メモ化による再帰の最適化

メモ化は負(fù)荷の高い関數(shù)呼び出しの結(jié)果を保存します。これは、フィボナッチ計(jì)算などの再帰アルゴリズムで特に役立ちます。

from functools import lru_cache

@lru_cache(maxsize=1000)
def fibonacci(n):
    if n < 2:
        return n
    return fibonacci(n - 1) + fibonacci(n - 2)

このアプローチでは、追加メモリを最小限に抑えながら、時間の複雑さを軽減します。

6.デコレータで柔軟性を追加

Python デコレータは、コア ロジックを変更せずに、ロギングやタイミングなど、再利用可能な機(jī)能を複數(shù)の関數(shù)に適用する場合に役立ちます。

import time

def timer(func):
    def wrapper(*args, **kwargs):
        start_time = time.time()
        result = func(*args, **kwargs)
        print(f"{func.__name__} took {time.time() - start_time:.6f} seconds")
        return result
    return wrapper

@timer
def slow_function():
    time.sleep(1)

slow_function()

7. dataclass でデータモデルを明確にする

Python のデータクラスを使用すると、init、repr、比較メソッドが自動的に生成されるため、単純なデータ モデルの定義がより簡単かつ読みやすくなります。

def read_large_file(file_path):
    with open(file_path, 'r') as file:
        for line in file:
            yield line.strip()

これにより、定型コードが削減され、データ構(gòu)造がクリーンで保守可能に保たれます。

8.一致する構(gòu)造條件

Python 3.10 では、構(gòu)造パターン マッチングにより、冗長な if-else ステートメントを使用せずに複雑なデータ構(gòu)造を照合できます。

inventory = {"jeans": 500, "top": 600}
inventory.setdefault("shoes", 0)
print(inventory)

9. Chained と all() を置き換えます

複數(shù)の條件を一度に検証するには、all() を使用してコードを簡潔かつ読みやすく保ちます。

def start(): print("Start")
def stop(): print("Stop")
actions = {"start": start, "stop": stop}
action = "start"
actions.get(action, lambda: print("Invalid"))()

10.リスト內(nèi)包表記を活用する

リスト內(nèi)包表記により、特に単純な変換の場合、ループが簡潔かつ表現(xiàn)力豊かになります。

from collections import Counter
words = ["apple", "banana", "apple", "orange", "banana"]
counts = Counter(words)
print(counts)

従來のループよりも効率的で読みやすいです。

11.ジェネレータ式を理解して使用する

リストが必要ない場合は、ジェネレータ式を使用してメモリ効率を高めます。

from functools import lru_cache

@lru_cache(maxsize=1000)
def fibonacci(n):
    if n < 2:
        return n
    return fibonacci(n - 1) + fibonacci(n - 2)

ジェネレーター式は、オンデマンドで値を生成することでメモリ使用量を削減します。

12.並列反復(fù)のために zip() を試してください

zip() 関數(shù)を使用すると、複數(shù)のリストを並行して反復(fù)処理することが簡単になります。

import time

def timer(func):
    def wrapper(*args, **kwargs):
        start_time = time.time()
        result = func(*args, **kwargs)
        print(f"{func.__name__} took {time.time() - start_time:.6f} seconds")
        return result
    return wrapper

@timer
def slow_function():
    time.sleep(1)

slow_function()

13. with ステートメントでファイルを安全に処理する

with ステートメントは、スイートの終了後にファイルが適切に閉じられるようにするため、ファイル処理に最適です。

from dataclasses import dataclass

@dataclass
class Employee:
    name: str
    id: int
    salary: float

e = Employee("Alice", 1, 50000)
print(e)

これにより、リソース管理が簡素化され、エラーの可能性が最小限に抑えられます。

14.タイプヒントで安全性を追加

型ヒントによりコードが読みやすくなり、IDE が実行前に潛在的なエラーを検出できるようになります。

def describe_point(point):
    match point:
        case (0, 0):
            return "Origin"
        case (0, y):
            return f"On Y-axis at {y}"
        case (x, 0):
            return f"On X-axis at {x}"
        case (x, y):
            return f"Point at ({x}, {y})"

型ヒントは、特に大規(guī)模なコードベースでの保守性を向上させます。

15. or 條件 を any() で簡略化します

リスト內(nèi)の條件が true かどうかを確認(rèn)するには、連鎖した or 條件よりも any() の方が簡潔です。

fields = ["name", "email", "age"]
data = {"name": "Alice", "email": "alice@example.com", "age": 25}
if all(field in data for field in fields):
    print("All fields are present")

16. try-excel-else-finally を活用する

この構(gòu)造により、else と最終的にさまざまなシナリオを管理するための柔軟性が追加され、よりクリーンなエラー処理が可能になります。

squares = [x ** 2 for x in range(10)]

17.名前付きタプルを使用してデータを整理する

名前付きタプルはタプルに構(gòu)造を追加し、タプルをより読みやすく、自己文書化します。

sum_of_squares = sum(x ** 2 for x in range(1000))

18. f-Strings による str 連結(jié)の改善

f-String は、特に複雑な式の場合、従來の連結(jié)方法よりも高速で読みやすいです。

names = ["Alice", "Bob"]
ages = [25, 30]
for name, age in zip(names, ages):
    print(f"{name} is {age} years old")

19.効率的な反復(fù)のために itertools を使用する

itertools モジュールは、順列、組み合わせ、要素の繰り返しの生成など、効率的なループ オプションを提供します。

def read_large_file(file_path):
    with open(file_path, 'r') as file:
        for line in file:
            yield line.strip()

20.コンテキストマネージャーでコードをクリーンに保つ

カスタム コンテキスト マネージャーは、リソースの管理やタスクのクリーンアップに役立ち、読みやすさと安全性が向上します。

inventory = {"jeans": 500, "top": 600}
inventory.setdefault("shoes", 0)
print(inventory)

これらのテクニックを統(tǒng)合することで、より効率的であるだけでなく、読みやすく保守しやすい Python コードを作成できます。これらのヒントを試して、徐々に毎日のコーディング実踐に取り入れてください。

以上が効率的で読みやすい Python コードを作成するための強(qiáng)力なテクニックの詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國語 Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無料で

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中國語版

SublimeText3 中國語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強(qiáng)力な PHP 統(tǒng)合開発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Pythonの不適格またはPytestフレームワークは、自動テストをどのように促進(jìn)しますか? Pythonの不適格またはPytestフレームワークは、自動テストをどのように促進(jìn)しますか? Jun 19, 2025 am 01:10 AM

Pythonの不適格でPytestは、自動テストの書き込み、整理、および実行を簡素化する2つの広く使用されているテストフレームワークです。 1.両方とも、テストケースの自動発見をサポートし、明確なテスト構(gòu)造を提供します。 pytestはより簡潔で、テスト\ _から始まる関數(shù)が必要です。 2。それらはすべて組み込みのアサーションサポートを持っています:Unittestはアサートエクイアル、アサートトルー、およびその他の方法を提供しますが、Pytestは拡張されたアサートステートメントを使用して障害の詳細(xì)を自動的に表示します。 3.すべてがテストの準(zhǔn)備とクリーニングを処理するためのメカニズムを持っています:un

Pythonは、NumpyやPandasなどのライブラリとのデータ分析と操作にどのように使用できますか? Pythonは、NumpyやPandasなどのライブラリとのデータ分析と操作にどのように使用できますか? Jun 19, 2025 am 01:04 AM

pythonisidealfordataanalysisduetonumpyandpandas.1)numpyexcelsatnumericalcompitations withfast、多次元路面およびベクトル化された分離likenp.sqrt()

動的なプログラミング技術(shù)とは何ですか?また、Pythonでそれらを使用するにはどうすればよいですか? 動的なプログラミング技術(shù)とは何ですか?また、Pythonでそれらを使用するにはどうすればよいですか? Jun 20, 2025 am 12:57 AM

動的プログラミング(DP)は、複雑な問題をより単純なサブ問題に分解し、結(jié)果を保存して繰り返し計(jì)算を回避することにより、ソリューションプロセスを最適化します。主な方法は2つあります。1。トップダウン(暗記):問題を再帰的に分解し、キャッシュを使用して中間結(jié)果を保存します。 2。ボトムアップ(表):基本的な狀況からソリューションを繰り返し構(gòu)築します。フィボナッチシーケンス、バックパッキングの問題など、最大/最小値、最適なソリューション、または重複するサブ問題が必要なシナリオに適しています。Pythonでは、デコレータまたはアレイを通じて実裝でき、再帰的な関係を特定し、ベンチマークの狀況を定義し、空間の複雑さを最適化することに注意する必要があります。

__iter__と__next__を使用してPythonにカスタムイテレーターを?qū)g裝するにはどうすればよいですか? __iter__と__next__を使用してPythonにカスタムイテレーターを?qū)g裝するにはどうすればよいですか? Jun 19, 2025 am 01:12 AM

カスタムイテレーターを?qū)g裝するには、クラス內(nèi)の__iter__および__next__メソッドを定義する必要があります。 __iter__メソッドは、ループなどの反復(fù)環(huán)境と互換性があるように、通常は自己の反復(fù)オブジェクト自體を返します。 __next__メソッドは、各反復(fù)の値を制御し、シーケンスの次の要素を返し、アイテムがもうない場合、停止例外をスローする必要があります。 statusステータスを正しく追跡する必要があり、無限のループを避けるために終了條件を設(shè)定する必要があります。 fileファイルラインフィルタリングなどの複雑なロジック、およびリソースクリーニングとメモリ管理に注意を払ってください。 simple単純なロジックについては、代わりにジェネレーター関數(shù)の収率を使用することを検討できますが、特定のシナリオに基づいて適切な方法を選択する必要があります。

Pythonプログラミング言語とそのエコシステムの新たな傾向または將來の方向性は何ですか? Pythonプログラミング言語とそのエコシステムの新たな傾向または將來の方向性は何ですか? Jun 19, 2025 am 01:09 AM

Pythonの將來の傾向には、パフォーマンスの最適化、より強(qiáng)力なタイププロンプト、代替ランタイムの増加、およびAI/MLフィールドの継続的な成長が含まれます。第一に、CPYTHONは最適化を続け、スタートアップのより速い時間、機(jī)能通話の最適化、および提案された整數(shù)操作を通じてパフォーマンスを向上させ続けています。第二に、タイプのプロンプトは、コードセキュリティと開発エクスペリエンスを強(qiáng)化するために、言語とツールチェーンに深く統(tǒng)合されています。第三に、PyscriptやNuitkaなどの代替のランタイムは、新しい機(jī)能とパフォーマンスの利點(diǎn)を提供します。最後に、AIとデータサイエンスの分野は拡大し続けており、新興図書館はより効率的な開発と統(tǒng)合を促進(jìn)します。これらの傾向は、Pythonが常に技術(shù)の変化に適応し、その主要な位置を維持していることを示しています。

ソケットを使用してPythonでネットワークプログラミングを?qū)g行するにはどうすればよいですか? ソケットを使用してPythonでネットワークプログラミングを?qū)g行するにはどうすればよいですか? Jun 20, 2025 am 12:56 AM

Pythonのソケットモジュールは、クライアントおよびサーバーアプリケーションの構(gòu)築に適した低レベルのネットワーク通信機(jī)能を提供するネットワークプログラミングの基礎(chǔ)です。基本的なTCPサーバーを設(shè)定するには、Socket.Socket()を使用してオブジェクトを作成し、アドレスとポートをバインドし、.listen()を呼び出して接続をリッスンし、.accept()を介してクライアント接続を受け入れる必要があります。 TCPクライアントを構(gòu)築するには、ソケットオブジェクトを作成し、.connect()を呼び出してサーバーに接続する必要があります。次に、.sendall()を使用してデータと.recv()を送信して応答を受信します。複數(shù)のクライアントを処理するには、1つを使用できます。スレッド:接続するたびに新しいスレッドを起動します。 2。非同期I/O:たとえば、Asyncioライブラリは非ブロッキング通信を?qū)g現(xiàn)できます。注意すべきこと

Pythonでリストをスライスするにはどうすればよいですか? Pythonでリストをスライスするにはどうすればよいですか? Jun 20, 2025 am 12:51 AM

Pythonリストスライスに対するコアの答えは、[start:end:step]構(gòu)文をマスターし、その動作を理解することです。 1.リストスライスの基本形式はリスト[start:end:step]です。ここで、開始は開始インデックス(含まれています)、endはend index(含まれていません)、ステップはステップサイズです。 2。デフォルトで開始を省略して、0から開始を開始し、デフォルトで終了して終了し、デフォルトでステップを1に省略します。 3。my_list[:n]を使用して最初のnアイテムを取得し、my_list [-n:]を使用して最後のnアイテムを取得します。 4.ステップを使用して、my_list [:: 2]などの要素をスキップして、均一な數(shù)字と負(fù)のステップ値を取得できます。 5.一般的な誤解には、終了インデックスが含まれません

Pythonクラスの多型 Pythonクラスの多型 Jul 05, 2025 am 02:58 AM

Pythonオブジェクト指向プログラミングのコアコンセプトであるPythonは、「1つのインターフェイス、複數(shù)の実裝」を指し、異なるタイプのオブジェクトの統(tǒng)一処理を可能にします。 1。多型は、メソッドの書き換えを通じて実裝されます。サブクラスは、親クラスの方法を再定義できます。たとえば、Animal ClassのSOCK()方法は、犬と貓のサブクラスに異なる実裝を持っています。 2.多型の実用的な用途には、グラフィカルドローイングプログラムでdraw()メソッドを均一に呼び出すなど、コード構(gòu)造を簡素化し、スケーラビリティを向上させる、ゲーム開発における異なる文字の共通の動作の処理などが含まれます。 3. Pythonの実裝多型を満たす必要があります:親クラスはメソッドを定義し、子クラスはメソッドを上書きしますが、同じ親クラスの継承は必要ありません。オブジェクトが同じ方法を?qū)g裝する限り、これは「アヒル型」と呼ばれます。 4.注意すべきことには、メンテナンスが含まれます

See all articles