메인 콘텐츠로 건너뛰기
레지스트리에 연결된 아티팩트를 다운로드하려면 W&B Python SDK를 사용하세요. 아티팩트를 다운로드해 사용하려면 레지스트리 이름, 컬렉션 이름, 그리고 다운로드하려는 아티팩트 버전의 alias 또는 인덱스를 알아야 합니다. 아티팩트의 속성을 알고 나면 연결된 아티팩트 경로를 구성한 다음 아티팩트를 다운로드할 수 있습니다. 또는 W&B App UI에서 미리 생성된 코드 스니펫을 복사해 붙여넣어 레지스트리에 연결된 아티팩트를 다운로드할 수 있습니다.

연결된 아티팩트의 경로 구성

레지스트리에 연결된 아티팩트를 다운로드하려면 해당 아티팩트의 경로를 알아야 합니다. 이 경로는 레지스트리 이름, 컬렉션 이름, 그리고 사용하려는 아티팩트 버전의 alias 또는 인덱스로 구성됩니다. 아티팩트 버전의 레지스트리, 컬렉션, 그리고 alias 또는 인덱스를 알고 있으면 다음 문자열 템플릿을 사용해 연결된 아티팩트의 경로를 구성할 수 있습니다:
# 버전 인덱스가 지정된 Artifact 이름
f"wandb-registry-{REGISTRY}/{COLLECTION}:v{INDEX}"

# 별칭이 지정된 Artifact 이름
f"wandb-registry-{REGISTRY}/{COLLECTION}:{ALIAS}"
중괄호 {} 안의 값을, 액세스하려는 아티팩트 버전의 레지스트리 이름, 컬렉션, 그리고 alias 또는 인덱스로 바꾸세요. 연결된 아티팩트의 경로를 알고 있다면 wandb.Run.use_artifact() 방법을 사용해 아티팩트에 액세스하고 그 내용을 다운로드하세요. 다음 코드 스니펫은 W&B 레지스트리에 연결된 아티팩트를 사용하고 다운로드하는 방법을 보여줍니다. <> 안의 값은 자신의 값으로 바꾸세요:
import wandb

REGISTRY = '<registry_name>'
COLLECTION = '<collection_name>'
ALIAS = '<artifact_alias>'

with wandb.init(entity = '<team_name>', project = '<project_name>')  as run:
    artifact_name = f"wandb-registry-{REGISTRY}/{COLLECTION}:{ALIAS}"
    # artifact_name = '<artifact_name>' # W&B Registry UI에 표시된 전체 이름을 복사하여 붙여넣기
    fetched_artifact = run.use_artifact(artifact_or_name = artifact_name)  
    download_path = fetched_artifact.download()  
wandb.Run.use_artifact()를 사용하면 run을 생성하는 동시에 다운로드한 아티팩트를 해당 run의 입력으로 표시합니다. 아티팩트를 run의 입력으로 표시하면 W&B가 해당 아티팩트의 리니지를 추적할 수 있습니다. run을 생성하고 싶지 않다면 wandb.Api() 객체를 사용해 아티팩트에 액세스할 수 있습니다:
import wandb

REGISTRY = "<registry_name>"
COLLECTION = "<collection_name>"
VERSION = "<version>"

api = wandb.Api()
artifact_name = f"wandb-registry-{REGISTRY}/{COLLECTION}:{VERSION}"
artifact = api.artifact(name = artifact_name)
매개변수와 반환 유형은 API 레퍼런스의 wandb.Run.use_artifact()Artifact.download()를 참조하세요.
개인 entity를 보유하고 있으며 여러 조직에 속한 Users개인 entity를 보유하고 있으며 여러 조직에 속한 Users는 레지스트리에 연결된 아티팩트에 액세스할 때 조직 이름을 지정하거나 팀 entity를 사용해야 합니다.
import wandb

REGISTRY = "<registry_name>"
COLLECTION = "<collection_name>"
VERSION = "<version>"

# API를 초기화할 때 팀 entity를 사용해야 합니다.
api = wandb.Api(overrides={"entity": "<team-entity>"})
artifact_name = f"wandb-registry-{REGISTRY}/{COLLECTION}:{VERSION}"
artifact = api.artifact(name = artifact_name)

# 경로 구성
api = wandb.Api()
artifact_name = f"wandb-registry-{REGISTRY}/{COLLECTION}:{VERSION}"
artifact = api.artifact(name = artifact_name)

미리 생성된 코드 스니펫 복사 및 붙여넣기

W&B는 레지스트리에 연결된 아티팩트를 다운로드할 수 있도록 Python 스크립트, 노트북 또는 터미널에 복사해 붙여넣을 수 있는 코드 스니펫을 생성합니다.
  1. W&B 레지스트리로 이동합니다.
  2. 아티팩트가 포함된 레지스트리 이름을 선택합니다.
  3. 컬렉션 이름을 선택합니다.
  4. 아티팩트 버전 목록에서 액세스하려는 버전을 선택합니다.
  5. 사용 탭을 선택합니다.
  6. 사용 API 섹션에 표시된 코드 스니펫을 복사합니다.
  7. 코드 스니펫을 Python 스크립트, 노트북 또는 터미널에 붙여넣습니다.
레지스트리 UI에서 사용 코드 스니펫을 찾아 복사하는 단계별 절차