> ## Documentation Index
> Fetch the complete documentation index at: https://wb-21fd5541-docs-weave-byob-note.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

# Artifacts

> Créez, mettez à jour, téléchargez et gérez des W&B Artifacts pour la gestion des versions des données.

Créez, mettez à jour, téléchargez et gérez les W\&B Artifacts pour gérer les versions des données.

<div id="create-and-log-an-artifact">
  ## Créer et journaliser un artifact
</div>

```python theme={null}
"""
Crée et enregistre un artifact W&B. Commencez par créer un
objet artifact. Ensuite, ajoutez des fichiers, des répertoires ou des références externes à l'artifact.
Enfin, enregistrez l'artifact dans un run W&B.
"""
import wandb

# Créer un objet artifact
artifact = wandb.Artifact(name="<artifact_name>", type="<artifact_type>")

# Ajouter un ou plusieurs fichiers à l'artifact
artifact.add_file(local_path="data/file1.csv")

# Ajouter récursivement un répertoire à l'artifact
artifact.add_dir(local_path="data/directory")

# Ajouter une référence URI externe à l'artifact
artifact.add_reference(uri="s3://my-bucket/path/to/data.csv")

with wandb.init(project="<project>") as run:
    # Le code d'entraînement et de logging se place ici

    # Exemple d'enregistrement d'un artifact
    run.log_artifact(artifact)
```

<div id="track-an-external-artifact-by-adding-a-reference-to-a-cloud-storage-bucket-path">
  ## Suivre un artifact externe en ajoutant une référence au chemin d’un bucket de stockage cloud
</div>

```python theme={null}
"""
Suit un artifact externe en ajoutant une référence à un chemin de bucket de stockage cloud.
"""

import wandb

# Créer un objet artifact
artifact = wandb.Artifact(name="<artifact_name>", type="<artifact_type>")

# Ajouter une référence au chemin du bucket
artifact.add_reference(uri = "uri/to/your/bucket/path")

# Initialiser un run W&B
with wandb.init(project="<project>") as run:

  # Journaliser les métadonnées de l'artifact
  run.log_artifact(artifact)
```

<div id="delete-specific-artifact-version-from-a-run">
  ## Supprimer une version spécifique d’un artifact associée à un run
</div>

```python theme={null}
"""
Supprime une version spécifique d'un artifact d'un run W&B. Définissez delete_aliaes sur `True` 
si l'artifact possède un alias associé.
"""
import wandb

# Initialiser l'API W&B
api = wandb.Api()

# Obtenir le run par son chemin. Composé de <entity>/<project>/<run_path>
runs = api.run("<entity>/<project>/<run_path>")

# wandb.Api().Run.logged_artifacts() renvoie une liste de versions d'artifacts
# composée du nom de l'artifact et de la version <artifact_name>:v<version_number>
for artifact_version in runs.logged_artifacts():
    # Récupère les deux derniers caractères du nom de la version de l'artifact (str),
    # qui correspondent au numéro de version
    if artifact_version.name[-2:] == "v"+ "<version_number>":
        artifact_version.delete(delete_aliases=True)
```

<div id="delete-an-artifact-collection">
  ## Supprimer une collection d'artifact
</div>

```python theme={null}
"""
Supprimer une artifact collection de W&B.
"""
import wandb

# Initialiser l'API W&B
api = wandb.Api()

# Supprimer une artifact collection par son nom et son type
# Format du nom : <entity>/<project>/<run_path>
collection = api.artifact_collection(
    name="<entity>/<project>/<run_path>",
    type_name="<artifact_type>"
)

collection.delete()
```

<div id="download-specific-files-or-sub-folders-from-artifacts">
  ## Télécharger des fichiers spécifiques ou des sous-dossiers à partir d’Artifacts
</div>

```python theme={null}
"""
Télécharge des fichiers spécifiques ou des sous-dossiers depuis les W&B Artifacts. La même
logique s'applique aux artifacts externes.
"""
import wandb

with wandb.init(project="<project>") as run:
    # Indiquer l'artifact à utiliser. Le format est "nom:alias"
    artifact = run.use_artifact("<artifact_name>:<alias>")

    # Télécharger un fichier spécifique ou un sous-dossier
    artifact.download(path_prefix="<file_name>") # télécharge uniquement le fichier ou le dossier spécifié
```

<div id="download-files-or-entire-artifacts">
  ## Télécharger des fichiers ou des artifacts complets
</div>

```python theme={null}
"""
Télécharge des fichiers ou des artifacts entiers depuis W&B. La même
logique s'applique aux artifacts externes.
"""

import wandb    

with wandb.init(project="<project>") as run:
    # Indiquer l'artifact à utiliser. Le format est "nom:alias"
    artifact = run.use_artifact("<artifact_name>:<alias>")

    # Télécharge le fichier depuis l'artifact au chemin nom
    # Si artifact.add_reference() a été utilisé, renvoie l'URL de référence
    entry = artifact.get_entry("<file_name>")

    # Télécharger l'artifact entier
    datadir = artifact.download()
```

<div id="add-one-or-more-aliases-to-an-artifact-when-logging-it">
  ## Ajouter un ou plusieurs alias à un artifact au moment de sa journalisation
</div>

```python theme={null}
"""
Ajouter un ou plusieurs alias à un artifact lors de son enregistrement dans W&B.
"""
import wandb

# Créer un artifact
artifact = wandb.Artifact(name="<artifact_name>", type="<artifact_type>")
# Ajouter des fichiers à l'artifact
artifact.add_file("<file_path>")

with wandb.init(project="<project>") as run:
    # Enregistrer l'artifact avec des alias
    run.log_artifact(artifact, aliases=["<alias1>", "<alias2>"])
```

<div id="add-an-alias-to-an-existing-artifact">
  ## Ajouter un alias à un artifact existant
</div>

```python theme={null}
"""
Ajoute un alias à un artifact W&B existant.
"""
import wandb

# Récupérer un artifact existant et lui ajouter un alias
artifact = wandb.Api().artifact("entity/project/artifact:version")
artifact.aliases = ["<new-alias>"]
artifact.save()
```

<div id="add-a-tag-to-an-artifact-when-logging-it">
  ## Ajouter un tag à un artifact au moment de sa journalisation
</div>

```python theme={null}
"""
Ajouter un tag à un artifact lors de son enregistrement dans W&B.
"""
import wandb

# Créer un artifact
artifact = wandb.Artifact(name="<artifact_name>", type="<artifact_type>")

# Enregistrer l'artifact avec des tags
with wandb.init(project="<project>") as run:
    run.log_artifact(artifact, tags=["<tag1>", "<tag2>"])
```

<div id="add-a-tag-to-an-existing-artifact">
  ## Ajouter un tag sur un artifact existant
</div>

```python theme={null}
"""
Ajoute un tag à un artifact W&B existant.
"""
import wandb

# Récupérer un artifact existant et lui ajouter un tag
artifact = wandb.Api().artifact("entity/project/artifact:version")
artifact.tags = ["new-tag"]
artifact.save()
```

<div id="create-and-log-an-artifact-with-a-ttl-policy">
  ## Créer et journaliser un artifact doté d’une politique TTL
</div>

```python theme={null}
"""
Créer et enregistrer un artifact avec une politique TTL dans W&B.
"""
import wandb
from datetime import timedelta

# Créer un artifact avec une politique TTL
artifact = wandb.Artifact(name="<artifact_name>", type="<artifact_type>")
artifact.add_file("<file_path>")
artifact.ttl = timedelta(days=30)  # Définir la politique TTL

with wandb.init(project="<project>", entity="<entity>") as run:
    # Enregistrer l'artifact avec la politique TTL
    run.log_artifact(artifact)
```

<div id="update-the-ttl-policy-of-an-existing-artifact">
  ## Mettre à jour la politique TTL d’un artifact existant
</div>

```python theme={null}
"""
Mettre à jour la politique TTL d'un artifact existant dans W&B.
"""
import wandb
from datetime import timedelta

# Initialiser l'API W&B
api = wandb.Api()

# Récupérer l'artifact existant
artifact = api.artifact("<entity/project/artifact:alias>")

# Ajouter ou mettre à jour la politique TTL. Indiquer la durée souhaitée.
artifact.ttl = timedelta(days=365)  # Suppression dans un an

# Enregistrer l'artifact mis à jour
artifact.save()
```

<div id="update-an-existing-artifacts-description-within-a-run">
  ## Mettre à jour la description d'un artifact existant au sein d'un run
</div>

```python theme={null}
"""
Mettre à jour la description d'un artifact W&B existant dans un run W&B.

Ce code initialise un run W&B, récupère l'artifact spécifié par nom et alias,
met à jour sa description et enregistre les modifications.
"""
import wandb

with wandb.init(entity="<entity>", project="<project>") as run:
    # Récupérer l'artifact par nom et alias
    artifact = run.use_artifact(artifact_or_name="<artifact>:<alias>")
    # Mettre à jour la description de l'artifact
    artifact.description = "<description>"
    # Enregistrer l'artifact mis à jour
    artifact.save()
```

<div id="given-an-existing-artifact-update-its-description-metadata-and-aliases-without-creating-a-new-run">
  ## À partir d’un artifact existant, mettez à jour sa description, ses métadonnées et ses alias sans créer de nouveau run
</div>

```python theme={null}
"""
À partir d'un artifact existant, mettre à jour sa description, ses métadonnées et ses alias
sans créer un nouveau run.
"""
import wandb

api = wandb.Api()

artifact = api.artifact(name="<entity/project/artifact:alias>")

# Mettre à jour la description
artifact.description = "My new description"

# Mettre à jour sélectivement les clés de métadonnées
artifact.metadata["oldKey"] = "new value"

# Remplacer entièrement les métadonnées
artifact.metadata = {"newKey": "new value"}

# Ajouter un alias
artifact.aliases.append("best")

# Supprimer un alias
artifact.aliases.remove("latest")

# Remplacer complètement les alias
artifact.aliases = ["replaced"]

# Enregistrer toutes les modifications de l'artifact
artifact.save()
```
