亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

ホームページ バックエンド開発 Python チュートリアル PydanticAI: 本番環(huán)境に対応した AI アプリケーションを構(gòu)築するための包括的なガイド

PydanticAI: 本番環(huán)境に対応した AI アプリケーションを構(gòu)築するための包括的なガイド

Dec 30, 2024 am 08:54 AM

PydanticAI: A Comprehensive Guide to Building Production-Ready AI Applications

PydanticAI は、Generative AI を使用して運(yùn)用グレードのアプリケーションの開発を合理化するように設(shè)計(jì)された強(qiáng)力な Python フレームワーク です。これは、広く使用されているデータ検証ライブラリである Pydantic と同じチームによって構(gòu)築されており、FastAPI の革新的で人間工學(xué)に基づいた設(shè)計(jì)を AI アプリケーション開発の分野に導(dǎo)入することを目的としています。 PydanticAI は、タイプ セーフティ、モジュール性、他の Python ツールとのシームレスな統(tǒng)合に重點(diǎn)を置いています。

中心となる概念

PydanticAI は、いくつかの重要な概念を中心に展開します。

エージェント

エージェントは、大規(guī)模言語モデル (LLM) と対話するための 主要なインターフェースです。エージェントは、次のようなさまざまなコンポーネントのコンテナとして機(jī)能します。

  • システム プロンプト: LLM の指示。靜的文字列または動(dòng)的関數(shù)として定義されます。
  • 関數(shù)ツール: LLM が追加情報(bào)を取得したり、アクションを?qū)g行したりするために呼び出すことができる関數(shù)。
  • 構(gòu)造化結(jié)果タイプ: LLM が実行の最後に返さなければならないデータ型。
  • 依存関係の種類: システム プロンプト関數(shù)、ツール、結(jié)果バリデーターが使用する可能性のあるデータまたはサービス。
  • LLM モデル: エージェントが使用する LLM。エージェントの作成時(shí)または実行時(shí)に設(shè)定できます。

エージェントは再利用できるように設(shè)計(jì)されており、通常は一度インスタンス化され、アプリケーション全體で再利用されます。

システムプロンプト

システム プロンプトは、開発者によって LLM に提供される指示です。それらは次のとおりです:

  • 靜的システム プロンプト: エージェントの作成時(shí)に、エージェント コンストラクターの system_prompt パラメーターを使用して定義されます。
  • 動(dòng)的システム プロンプト: @agent.system_prompt で修飾された関數(shù)によって定義されます。これらは、RunContext オブジェクトを介して、依存関係などの実行時(shí)情報(bào)にアクセスできます。

単一のエージェントは靜的システム プロンプトと動(dòng)的システム プロンプトの両方を使用でき、これらは実行時(shí)に定義された順序で追加されます。

from pydantic_ai import Agent, RunContext
from datetime import date

agent = Agent(
    'openai:gpt-4o',
    deps_type=str,
    system_prompt="Use the customer's name while replying to them.",
)

@agent.system_prompt
def add_the_users_name(ctx: RunContext[str]) -> str:
    return f"The user's name is {ctx.deps}."

@agent.system_prompt
def add_the_date() -> str:
    return f'The date is {date.today()}.'

result = agent.run_sync('What is the date?', deps='Frank')
print(result.data)
#> Hello Frank, the date today is 2032-01-02.

機(jī)能ツール

関數(shù)ツールを使用すると、LLM は外部情報(bào)にアクセスしたり、システム プロンプト自體では利用できないアクションを?qū)g行したりできます。ツールはいくつかの方法で登録できます:

  • @agent.tool デコレータ: RunContext 経由でエージェントのコンテキストにアクセスする必要があるツール用。
  • @agent.tool_plain デコレータ: エージェントのコンテキストにアクセスする必要のないツール用。
  • エージェント コンストラクターの
  • tools キーワード引數(shù): Tool クラスのプレーン関數(shù)またはインスタンスを受け取ることができ、ツール定義をより詳細(xì)に制御できます。
from pydantic_ai import Agent, RunContext
from datetime import date

agent = Agent(
    'openai:gpt-4o',
    deps_type=str,
    system_prompt="Use the customer's name while replying to them.",
)

@agent.system_prompt
def add_the_users_name(ctx: RunContext[str]) -> str:
    return f"The user's name is {ctx.deps}."

@agent.system_prompt
def add_the_date() -> str:
    return f'The date is {date.today()}.'

result = agent.run_sync('What is the date?', deps='Frank')
print(result.data)
#> Hello Frank, the date today is 2032-01-02.

ツール パラメーターは関數(shù)シグネチャから抽出され、ツールの JSON スキーマの構(gòu)築に使用されます。関數(shù)の docstring は、ツールの説明とスキーマ內(nèi)のパラメーターの説明を生成するために使用されます。

依存関係

依存関係は、依存関係注入システムを介して、エージェントのシステム プロンプト、ツール、結(jié)果バリデーターにデータとサービスを提供します。依存関係には RunContext オブジェクトを通じてアクセスします。任意の Python タイプを使用できますが、データクラスは複數(shù)の依存関係を管理する便利な方法です。

import random
from pydantic_ai import Agent, RunContext

agent = Agent(
    'gemini-1.5-flash',
    deps_type=str,
    system_prompt=(
        "You're a dice game, you should roll the die and see if the number "
        "you get back matches the user's guess. If so, tell them they're a winner. "
        "Use the player's name in the response."
    ),
)

@agent.tool_plain
def roll_die() -> str:
    """Roll a six-sided die and return the result."""
    return str(random.randint(1, 6))

@agent.tool
def get_player_name(ctx: RunContext[str]) -> str:
    """Get the player's name."""
    return ctx.deps

dice_result = agent.run_sync('My guess is 4', deps='Anne')
print(dice_result.data)
#> Congratulations Anne, you guessed correctly! You're a winner!

結(jié)果

結(jié)果は、エージェントの実行から返される最終値です。これらは RunResult (同期および非同期実行の場合) または StreamedRunResult (ストリーミング実行の場合) にラップされ、使用狀況データとメッセージ履歴へのアクセスを提供します。結(jié)果はプレーンテキストまたは構(gòu)造化データであり、Pydantic を使用して検証されます。

from dataclasses import dataclass
import httpx
from pydantic_ai import Agent, RunContext

@dataclass
class MyDeps:
    api_key: str
    http_client: httpx.AsyncClient

agent = Agent(
    'openai:gpt-4o',
    deps_type=MyDeps,
)

@agent.system_prompt
async def get_system_prompt(ctx: RunContext[MyDeps]) -> str:
    response = await ctx.deps.http_client.get(
        'https://example.com',
        headers={'Authorization': f'Bearer {ctx.deps.api_key}'},
    )
    response.raise_for_status()
    return f'Prompt: {response.text}'

async def main():
    async with httpx.AsyncClient() as client:
        deps = MyDeps('foobar', client)
        result = await agent.run('Tell me a joke.', deps=deps)
        print(result.data)
        #> Did you hear about the toothpaste scandal? They called it Colgate.

@agent.result_validator デコレータを介して追加された結(jié)果バリデータは、特に検証に IO が必要で非同期である場合に、さらに検証ロジックを追加する方法を提供します。

主な特長

PydanticAI は、AI アプリケーション開発にとって魅力的な選択肢となるいくつかの重要な機(jī)能を備えています。

  • モデルに依存しない: PydanticAI は、OpenAI、Anthropic、Gemini、Ollama、Groq、Mistral などのさまざまな LLM をサポートしています。また、他のモデルのサポートを?qū)g裝するためのシンプルなインターフェイスも提供します。
  • 型安全性: mypy や pyright などの靜的型チェッカーとシームレスに動(dòng)作するように設(shè)計(jì)されています。これにより、依存関係と結(jié)果の型の型チェックが可能になります。
  • Python 中心の設(shè)計(jì): 使い慣れた Python 制御フローとエージェント構(gòu)成を活用して AI プロジェクトを構(gòu)築し、標(biāo)準(zhǔn)的な Python プラクティスを簡単に適用できます。
  • 構(gòu)造化された応答: Pydantic を使用してモデル出力を検証および構(gòu)造化し、一貫した応答を保証します。
  • 依存関係注入システム: エージェントのコンポーネントにデータとサービスを提供する依存関係注入システムを提供し、テスト容易性と反復(fù)開発を強(qiáng)化します。
  • ストリーミング応答: 即時(shí)検証によるストリーミング LLM 出力をサポートし、迅速かつ正確な結(jié)果を可能にします。

エージェントとの連攜

エージェントの実行

エージェントはいくつかの方法で実行できます:

  • run_sync(): 同期実行用。
  • run(): 非同期実行の場合。
  • run_stream(): ストリーミング応答用。
from pydantic_ai import Agent, RunContext
from datetime import date

agent = Agent(
    'openai:gpt-4o',
    deps_type=str,
    system_prompt="Use the customer's name while replying to them.",
)

@agent.system_prompt
def add_the_users_name(ctx: RunContext[str]) -> str:
    return f"The user's name is {ctx.deps}."

@agent.system_prompt
def add_the_date() -> str:
    return f'The date is {date.today()}.'

result = agent.run_sync('What is the date?', deps='Frank')
print(result.data)
#> Hello Frank, the date today is 2032-01-02.

會(huì)話

エージェントの実行は會(huì)話全體を表す場合がありますが、特に対話間の狀態(tài)を維持する場合には、會(huì)話が複數(shù)の実行で構(gòu)成されることもあります。 message_history 引數(shù)を使用して以前の実行からのメッセージを渡し、會(huì)話を続行できます。

import random
from pydantic_ai import Agent, RunContext

agent = Agent(
    'gemini-1.5-flash',
    deps_type=str,
    system_prompt=(
        "You're a dice game, you should roll the die and see if the number "
        "you get back matches the user's guess. If so, tell them they're a winner. "
        "Use the player's name in the response."
    ),
)

@agent.tool_plain
def roll_die() -> str:
    """Roll a six-sided die and return the result."""
    return str(random.randint(1, 6))

@agent.tool
def get_player_name(ctx: RunContext[str]) -> str:
    """Get the player's name."""
    return ctx.deps

dice_result = agent.run_sync('My guess is 4', deps='Anne')
print(dice_result.data)
#> Congratulations Anne, you guessed correctly! You're a winner!

使用制限

PydanticAI は、トークンとリクエストの數(shù)を制限するための settings.UsageLimits 構(gòu)造を提供します。これらの設(shè)定は、usage_limits 引數(shù)を介して実行関數(shù)に適用できます。

from dataclasses import dataclass
import httpx
from pydantic_ai import Agent, RunContext

@dataclass
class MyDeps:
    api_key: str
    http_client: httpx.AsyncClient

agent = Agent(
    'openai:gpt-4o',
    deps_type=MyDeps,
)

@agent.system_prompt
async def get_system_prompt(ctx: RunContext[MyDeps]) -> str:
    response = await ctx.deps.http_client.get(
        'https://example.com',
        headers={'Authorization': f'Bearer {ctx.deps.api_key}'},
    )
    response.raise_for_status()
    return f'Prompt: {response.text}'

async def main():
    async with httpx.AsyncClient() as client:
        deps = MyDeps('foobar', client)
        result = await agent.run('Tell me a joke.', deps=deps)
        print(result.data)
        #> Did you hear about the toothpaste scandal? They called it Colgate.

モデル設(shè)定

settings.ModelSettings 構(gòu)造體を使用すると、溫度、max_tokens、タイムアウトなどのパラメーターを通じてモデルの動(dòng)作を微調(diào)整できます。これらは、実行関數(shù)の model_settings 引數(shù)を介して適用できます。

from pydantic import BaseModel
from pydantic_ai import Agent

class CityLocation(BaseModel):
    city: str
    country: str

agent = Agent('gemini-1.5-flash', result_type=CityLocation)
result = agent.run_sync('Where were the olympics held in 2012?')
print(result.data)
#> city='London' country='United Kingdom'

機(jī)能ツールの詳細(xì)

ツールの登録

ツールは、@agent.tool デコレータ (コンテキストが必要なツールの場合)、@agent.tool_plain デコレータ (コンテキストのないツールの場合)、または Agent コンストラクタの tools 引數(shù)を使用して登録できます。

from pydantic_ai import Agent

agent = Agent('openai:gpt-4o')

# Synchronous run
result_sync = agent.run_sync('What is the capital of Italy?')
print(result_sync.data)
#> Rome

# Asynchronous run
async def main():
    result = await agent.run('What is the capital of France?')
    print(result.data)
    #> Paris

    async with agent.run_stream('What is the capital of the UK?') as response:
        print(await response.get_data())
        #> London

ツールスキーマ

パラメータの説明は docstring から抽出され、ツールの JSON スキーマに追加されます。ツールに JSON スキーマのオブジェクトとして表現(xiàn)できるパラメーターが 1 つある場合、スキーマはそのオブジェクトのみに簡略化されます。

from pydantic_ai import Agent

agent = Agent('openai:gpt-4o', system_prompt='Be a helpful assistant.')
result1 = agent.run_sync('Tell me a joke.')
print(result1.data)
#> Did you hear about the toothpaste scandal? They called it Colgate.

result2 = agent.run_sync('Explain?', message_history=result1.new_messages())
print(result2.data)
#> This is an excellent joke invent by Samuel Colvin, it needs no explanation.

動(dòng)的ツール

ツールは準(zhǔn)備関數(shù)を使用してカスタマイズできます。この関數(shù)は、ツール定義を変更するか、そのステップからツールを省略するために各ステップで呼び出されます。

from pydantic_ai import Agent
from pydantic_ai.settings import UsageLimits
from pydantic_ai.exceptions import UsageLimitExceeded

agent = Agent('claude-3-5-sonnet-latest')
try:
    result_sync = agent.run_sync(
        'What is the capital of Italy? Answer with a paragraph.',
        usage_limits=UsageLimits(response_tokens_limit=10),
    )
except UsageLimitExceeded as e:
    print(e)
    #> Exceeded the response_tokens_limit of 10 (response_tokens=32)

メッセージとチャット履歴

メッセージへのアクセス

エージェントの実行中に交換されるメッセージには、RunResult オブジェクトと StreamedRunResult オブジェクトの all_messages() メソッドと new_messages() メソッドを介してアクセスできます。

from pydantic_ai import Agent

agent = Agent('openai:gpt-4o')
result_sync = agent.run_sync(
    'What is the capital of Italy?',
    model_settings={'temperature': 0.0},
)
print(result_sync.data)
#> Rome

メッセージの再利用

メッセージを message_history パラメータに渡して、複數(shù)のエージェント実行にわたって會(huì)話を続けることができます。 message_history が設(shè)定されていて空でない場合、新しいシステム プロンプトは生成されません。

メッセージフォーマット

メッセージ形式はモデルに依存しないので、異なるエージェントでメッセージを使用したり、異なるモデルを使用する同じエージェントでメッセージを使用したりできます。

デバッグとモニタリング

ピダンティック?ログファイア

PydanticAI は、アプリケーション全體の監(jiān)視とデバッグを可能にする可観測性プラットフォームである Pydantic Logfire と統(tǒng)合します。 Logfire は次の目的で使用できます:

  • リアルタイム デバッグ: アプリケーションで何が起こっているかをリアルタイムで確認(rèn)します。
  • アプリケーションのパフォーマンスの監(jiān)視: SQL クエリとダッシュボードを使用します。

Logfire で PydanticAI を使用するには、logfire オプション グループを使用してインストールします: pip install 'pydantic-ai[logfire]'。次に、Logfire プロジェクトを構(gòu)成し、環(huán)境を認(rèn)証する必要があります。

インストールとセットアップ

インストール

PydanticAI は pip を使用してインストールできます:

from pydantic_ai import Agent, RunContext
from datetime import date

agent = Agent(
    'openai:gpt-4o',
    deps_type=str,
    system_prompt="Use the customer's name while replying to them.",
)

@agent.system_prompt
def add_the_users_name(ctx: RunContext[str]) -> str:
    return f"The user's name is {ctx.deps}."

@agent.system_prompt
def add_the_date() -> str:
    return f'The date is {date.today()}.'

result = agent.run_sync('What is the date?', deps='Frank')
print(result.data)
#> Hello Frank, the date today is 2032-01-02.

スリム インストールは、次のような特定のモデルを使用することもできます。

import random
from pydantic_ai import Agent, RunContext

agent = Agent(
    'gemini-1.5-flash',
    deps_type=str,
    system_prompt=(
        "You're a dice game, you should roll the die and see if the number "
        "you get back matches the user's guess. If so, tell them they're a winner. "
        "Use the player's name in the response."
    ),
)

@agent.tool_plain
def roll_die() -> str:
    """Roll a six-sided die and return the result."""
    return str(random.randint(1, 6))

@agent.tool
def get_player_name(ctx: RunContext[str]) -> str:
    """Get the player's name."""
    return ctx.deps

dice_result = agent.run_sync('My guess is 4', deps='Anne')
print(dice_result.data)
#> Congratulations Anne, you guessed correctly! You're a winner!

Logfire の統(tǒng)合

Logfire で PydanticAI を使用するには、logfire オプション グループを使用してインストールします。

from dataclasses import dataclass
import httpx
from pydantic_ai import Agent, RunContext

@dataclass
class MyDeps:
    api_key: str
    http_client: httpx.AsyncClient

agent = Agent(
    'openai:gpt-4o',
    deps_type=MyDeps,
)

@agent.system_prompt
async def get_system_prompt(ctx: RunContext[MyDeps]) -> str:
    response = await ctx.deps.http_client.get(
        'https://example.com',
        headers={'Authorization': f'Bearer {ctx.deps.api_key}'},
    )
    response.raise_for_status()
    return f'Prompt: {response.text}'

async def main():
    async with httpx.AsyncClient() as client:
        deps = MyDeps('foobar', client)
        result = await agent.run('Tell me a joke.', deps=deps)
        print(result.data)
        #> Did you hear about the toothpaste scandal? They called it Colgate.

サンプルは別のパッケージとして入手できます:

from pydantic import BaseModel
from pydantic_ai import Agent

class CityLocation(BaseModel):
    city: str
    country: str

agent = Agent('gemini-1.5-flash', result_type=CityLocation)
result = agent.run_sync('Where were the olympics held in 2012?')
print(result.data)
#> city='London' country='United Kingdom'

テストと評(píng)価

単體テスト

単體テストでは、アプリケーション コードが期待どおりに動(dòng)作するかどうかを検証します。 PydanticAI の場合は、次の戦略に従ってください:

  • pytest をテスト ハーネスとして使用します。
  • 実際のモデルの代わりに TestModel または FunctionModel を使用します。
  • Agent.override を使用して、アプリケーション ロジック內(nèi)のモデルを置き換えます。
  • テスト以外のモデルへの誤った呼び出しを防ぐために、ALLOW_MODEL_REQUESTS=False をグローバルに設(shè)定します。
from pydantic_ai import Agent

agent = Agent('openai:gpt-4o')

# Synchronous run
result_sync = agent.run_sync('What is the capital of Italy?')
print(result_sync.data)
#> Rome

# Asynchronous run
async def main():
    result = await agent.run('What is the capital of France?')
    print(result.data)
    #> Paris

    async with agent.run_stream('What is the capital of the UK?') as response:
        print(await response.get_data())
        #> London

エヴァルス

評(píng)価は LLM のパフォーマンスを測定するために使用され、単體テストというよりはベンチマークに似ています。 Evals は、特定のアプリケーションに対して LLM がどのように実行されるかを測定することに重點(diǎn)を置いています。これは、エンドツーエンドのテスト、合成自己完結(jié)型テスト、LLM を使用した LLM の評(píng)価、または運(yùn)用環(huán)境でのエージェントのパフォーマンスの測定によって実行できます。

使用例の例

PydanticAI はさまざまなユースケースで使用できます:

  • ルーレット ホイール: 整數(shù)の依存関係とブール値の結(jié)果を持つエージェントを使用してルーレット ホイールをシミュレートします。
  • チャット アプリケーション: 複數(shù)の実行でチャット アプリケーションを作成し、message_history を使用して以前のメッセージを渡します。
  • 銀行サポート エージェント: ツール、依存関係の注入、構(gòu)造化された応答を使用して銀行のサポート エージェントを構(gòu)築します。
  • 天気予報(bào): 関數(shù)ツールと依存関係を使用して、場所と日付に基づいて天気予報(bào)を返すアプリケーションを作成します。
  • SQL 生成: 結(jié)果バリデータを使用した検証を行い、ユーザー プロンプトから SQL クエリを生成します。

結(jié)論

PydanticAI は、型安全性とモジュール性を重視した AI アプリケーション開発のための堅(jiān)牢かつ柔軟なフレームワークを提供します。データの検証と構(gòu)造化に Pydantic を使用し、依存関係注入システムと組み合わせることで、信頼性が高く保守可能な AI アプリケーションを構(gòu)築するための理想的なツールになります。 PydanticAI は、広範(fàn)な LLM サポートと Pydantic Logfire などのツールとのシームレスな統(tǒng)合により、開発者が強(qiáng)力で本番環(huán)境に対応した AI 主導(dǎo)のプロジェクトを効率的に構(gòu)築できるようにします。

以上がPydanticAI: 本番環(huán)境に対応した AI アプリケーションを構(gòu)築するための包括的なガイドの詳細(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クラスの多型 Pythonクラスの多型 Jul 05, 2025 am 02:58 AM

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

Python関數(shù)引數(shù)とパラメーター Python関數(shù)引數(shù)とパラメーター Jul 04, 2025 am 03:26 AM

パラメーターは関數(shù)を定義するときはプレースホルダーであり、引數(shù)は呼び出し時(shí)に特定の値が渡されます。 1。位置パラメーターを順番に渡す必要があり、順序が正しくない場合は結(jié)果のエラーにつながります。 2。キーワードパラメーターはパラメーター名で指定されており、順序を変更して読みやすさを向上させることができます。 3.デフォルトのパラメーター値は、複製コードを避けるために定義されたときに割り當(dāng)てられますが、変數(shù)オブジェクトはデフォルト値として避ける必要があります。 4. Argsおよび *Kwargsは、不確実な數(shù)のパラメーターを処理でき、一般的なインターフェイスまたはデコレータに適していますが、読みやすさを維持するためには注意して使用する必要があります。

Pythonジェネレーターと反復(fù)器を説明します。 Pythonジェネレーターと反復(fù)器を説明します。 Jul 05, 2025 am 02:55 AM

イテレータは、__iter __()および__next __()メソッドを?qū)g裝するオブジェクトです。ジェネレーターは、単純化されたバージョンのイテレーターです。これは、収量キーワードを介してこれらのメソッドを自動(dòng)的に実裝しています。 1. Iteratorは、次の()を呼び出すたびに要素を返し、要素がなくなると停止例外をスローします。 2。ジェネレーターは関數(shù)定義を使用して、オンデマンドでデータを生成し、メモリを保存し、無限シーケンスをサポートします。 3。既存のセットを処理するときに反復(fù)器を使用すると、大きなファイルを読み取るときに行ごとにロードするなど、ビッグデータや怠zyな評(píng)価を動(dòng)的に生成するときにジェネレーターを使用します。注:リストなどの反復(fù)オブジェクトは反復(fù)因子ではありません。イテレーターがその端に達(dá)した後、それらは再作成する必要があり、発電機(jī)はそれを一度しか通過できません。

python `@classmethod`デコレーターが説明しました python `@classmethod`デコレーターが説明しました Jul 04, 2025 am 03:26 AM

クラスメソッドは、@ClassMethodデコレーターを介してPythonで定義されるメソッドです。最初のパラメーターはクラス自體(CLS)で、クラス?fàn)顟B(tài)へのアクセスまたは変更に使用されます。特定のインスタンスではなく、クラス全體に影響を與えるクラスまたはインスタンスを通じて呼び出すことができます。たとえば、Personクラスでは、show_count()メソッドは作成されたオブジェクトの數(shù)を數(shù)えます。クラスメソッドを定義するときは、@ClassMethodデコレータを使用して、Change_Var(new_Value)メソッドなどの最初のパラメーターCLSに名前を付けてクラス変數(shù)を変更する必要があります。クラス方法は、インスタンスメソッド(自己パラメーター)および靜的メソッド(自動(dòng)パラメーターなし)とは異なり、工場の方法、代替コンストラクター、およびクラス変數(shù)の管理に適しています。一般的な用途には以下が含まれます。

PythonでAPI認(rèn)証を処理する方法 PythonでAPI認(rèn)証を処理する方法 Jul 13, 2025 am 02:22 AM

API認(rèn)証を扱うための鍵は、認(rèn)証方法を正しく理解して使用することです。 1。Apikeyは、通常、リクエストヘッダーまたはURLパラメーターに配置されている最も単純な認(rèn)証方法です。 2。BasicAuthは、內(nèi)部システムに適したBase64エンコード送信にユーザー名とパスワードを使用します。 3。OAUTH2は、最初にclient_idとclient_secretを介してトークンを取得し、次にリクエストヘッダーにbearertokenを持ち込む必要があります。 4。トークンの有効期限に対処するために、トークン管理クラスをカプセル化し、トークンを自動(dòng)的に更新できます。要するに、文書に従って適切な方法を選択し、重要な情報(bào)を安全に保存することが重要です。

Python Magic MethodsまたはDunder Methodとは何ですか? Python Magic MethodsまたはDunder Methodとは何ですか? Jul 04, 2025 am 03:20 AM

PythonのMagicMethods(またはDunder Methods)は、オブジェクトの動(dòng)作を定義するために使用される特別な方法であり、二重のアンダースコアで始まり、終了します。 1.オブジェクトは、追加、比較、文字列表現(xiàn)などの組み込み操作に応答できるようにします。 2.一般的なユースケースには、オブジェクトの初期化と表現(xiàn)(__init__、__Repr__、__str__)、算術(shù)操作(__ add__、__sub__、__mul__)、および比較操作(__eq__、___lt__)が含まれます。 3。それを使用するときは、彼らの行動(dòng)が期待を満たしていることを確認(rèn)してください。たとえば、__Repr__はリファクタリング可能なオブジェクトの式を返す必要があり、算術(shù)メソッドは新しいインスタンスを返す必要があります。 4.過剰使用または混亂を招くことは避ける必要があります。

Pythonメモリ管理はどのように機(jī)能しますか? Pythonメモリ管理はどのように機(jī)能しますか? Jul 04, 2025 am 03:26 AM

PythonManagesMemoryAutomatelyUsingTuntingAndagarBageCollector.ReferencountingTrackShowManyvariablesRefertoAnobject、およびThemeMoryisfreed.

python `@property`デコレーター python `@property`デコレーター Jul 04, 2025 am 03:28 AM

@Propertyは、プロパティとしてメソッドを裝備するために使用されるPythonのデコレーターであり、プロパティにアクセスするときに論理的判斷または値の動(dòng)的計(jì)算を可能にします。 1. @propertyデコレータを介してゲッターメソッドを定義し、外部が屬性へのアクセスなどのメソッドを呼び出すようにします。 2.チェック値の有効性など、.setterを使用して割り當(dāng)て動(dòng)作を制御できます。.setterが定義されていない場合、読み取り専用屬性です。 3.プロパティの割り當(dāng)て検証、屬性値の動(dòng)的生成、內(nèi)部実裝の詳細(xì)を隠すなどのシーンに適しています。 4.それを使用する場合、屬性名はプライベート変數(shù)名と異なるため、デッドループを避け、軽量操作に適していることに注意してください。 5。例では、サークルクラスは半徑を非陰性に制限し、個(gè)人クラスはfull_name屬性を動(dòng)的に生成します

See all articles