Strumento della riga di comando

Lo strumento earthengine è un programma di utilità che consente di gestire gli asset e le attività di Earth Engine dalla riga di comando. Viene installato automaticamente quando installi l'API Python. Per verificare se lo strumento è installato e funziona correttamente, digita quanto segue in una riga di comando:

    earthengine

Se lo strumento è installato correttamente, viene stampato un breve riepilogo dei comandi disponibili. Per ricevere assistenza su un comando specifico, utilizza:

    earthengine command -h

Quando installi l'API Python per la prima volta, devi accedere utilizzando il comandoauthenticate descritto di seguito. Le sezioni seguenti descrivono in modo più dettagliato i comandi disponibili.

Credenziali dell'account di servizio

Per utilizzare la CLI con le credenziali di un account di servizio, utilizza il flag service_account_file per indicare un file JSON contenente la chiave dell'account di servizio.

    earthengine --service_account_file=service_account_creds.json

Utilizzo in Colab

Lo strumento a riga di comando Earth Engine è preinstallato e pronto per l'uso in Google Colab.

Autenticazione

Effettua l'autenticazione per ogni nuova sessione di Colab o se la macchina virtuale scade per inattività (le credenziali non vengono salvate tra le sessioni).

Importa la libreria client Python e chiama ee.Authenticate() per attivare il flusso di autenticazione. Segui le istruzioni per completare l'autenticazione. Il valore predefinitoauth_mode in Colab è colab. Per altre opzioni, consulta la guida all'autenticazione.

import ee
ee.Authenticate()

Esecuzione del comando

Per eseguire utilità a riga di comando, come l'interfaccia a riga di comando di Earth Engine, devi anteporre alle chiamate dei comandi un punto esclamativo.

!earthengine -h

Impostare un progetto Cloud

Utilizza l'opzione --project per impostare un progetto Cloud per ogni singolo earthengine comando.

!earthengine --project my-project <command>

In alternativa, imposta un progetto predefinito da utilizzare per tutte le chiamate earthengine utilizzando il comando set_project. Il progetto verrà aggiunto a un file delle credenziali (~/.config/earthengine/credentials) e utilizzato per i comandi successivi, a meno che non venga ignorato dall'opzione --project. Imposta un progetto predefinito per ogni nuova sessione di Colab o se la macchina virtuale scade per inattività (le credenziali non vengono salvate nelle sessioni).

!earthengine set_project my-project

Riferimenti dei comandi

autenticare

Autentica lo strumento a riga di comando e la libreria client Python in Earth Engine. Esempio:

    earthengine authenticate

Earth Engine utilizza il protocollo OAuth 2.0 per autenticare i client. Il comando earthengine authenticate ti guiderà attraverso la procedura di autenticazione utilizzando il browser web.

Dovrai installare gcloud se utilizzi la modalità di autenticazione gcloud predefinita. Consulta le altre modalità di autenticazione disponibili tramite il parametro auth_mode nella guida all'autenticazione.

acl

Stampa o aggiorna l'elenco di controllo dell'accesso (ACL) di un asset Earth Engine. L'ACL controlla chi può leggere o scrivere in una risorsa. Esempi:

    earthengine acl get projects/my-project/assets/asset_id
    earthengine acl set public projects/my-project/assets/asset_id
    earthengine acl ch -u username@gmail.com:R projects/my-project/assets/asset_id

Il sottocomando get stampa una descrizione JSON dell'ACL. Il sottocomando set imposta un'ACL fornita in un file con lo stesso formato JSON. Puoi copiare un ACL da un asset ad altri salvando l'output di get e fornendolo a set.

Il sottocomando set accetta anche due nomi ACL speciali:

  • private: rimuove le autorizzazioni da tutti, ad eccezione del proprietario.
  • public: concede l'autorizzazione di lettura a tutti gli utenti.

Il sottocomando ch ti consente di apportare modifiche individuali a un'ACL. Per concedere l'autorizzazione di lettura, specifica -u username@gmail.com:R, per concedere l'autorizzazione di scrittura, specifica -u username@gmail.com:W e per rimuovere le autorizzazioni di un utente, specifica -d username@gmail.com. L'identificatore utente speciale AllUsers può essere utilizzato per concedere o revocare l'autorizzazione di lettura a o da tutti gli utenti. Tieni presente che la revoca delle autorizzazioni AllUsers non comporta la revoca di eventuali autorizzazioni aggiuntive che potresti aver anche concesso a singoli utenti.

asset

Stampa o aggiorna i metadati associati a una risorsa Earth Engine. Esempi:

    earthengine asset info projects/my-project/assets/asset_id
    earthengine asset set -p name=value projects/my-project/assets/asset_id

Il sottocomando info stampa informazioni dettagliate sulla risorsa, inclusi i relativi metadati, in formato JSON. Il sottocomando set imposta le singole proprietà di metadati su una risorsa.

I valori delle proprietà dei metadati impostati possono essere numeri o stringhe. Quando imposti i nomi delle proprietà utilizzando il flag --property o -p, separa il nome e il valore della proprietà con un segno di uguale. Il tipo di dati viene rilevato automaticamente oppure puoi specificarlo in modo esplicito anteponendo al nome della proprietà (string), (number) o (date). Ad esempio, questo imposta una proprietà con valore di stringa con il valore "42":

    earthengine asset set -p '(string)name=42' projects/my-project/assets/asset_id

Le virgolette in questo esempio impediscono alla shell di interpretare le parentesi. Potrebbero essere necessari o meno, a seconda della shell e della piattaforma.

Per eliminare una proprietà, impostala su null senza un tipo:

    earthengine asset set -p name=null projects/my-project/assets/asset_id

Le proprietà Data sono solo numeri che rappresentano un numero di millisecondi dall'epoca Unix (ovvero la mezzanotte del 1° gennaio 1970) e possono essere specificate direttamente come numero o in uno dei seguenti formati:

    YYYY-MM-DD
    YYYY-MM-DDThh:mm:ss
    YYYY-MM-DDThh:mm:ss.f

Si presume che il fuso orario sia UTC. Puoi impostare le proprietà speciali per l'ora di inizio e di fine utilizzando i flag --time_start e --time_end:

    earthengine asset set --time_start 1978-10-15T12:34:56 projects/my-project/assets/asset_id

cp

Copia una risorsa. Esempio:

    earthengine cp projects/my-project/assets/asset_id projects/my-project/assets/new_asset_id

create

Crea nuove cartelle e raccolte di immagini. Esempio:

    earthengine create folder projects/my-project/assets/folder_id
    earthengine create collection projects/my-project/assets/collection_id

Utilizza il sottocomando folder per creare cartelle e collection per creare raccolte di immagini. Puoi specificare l'opzione -p per creare in modo ricorsivo le cartelle principali come richiesto. Le cartelle e le immagini appena create hanno ACL private per impostazione predefinita.

ls

Elenca i contenuti di una o più cartelle o raccolte. Esempio:

    earthengine ls users/username

L'opzione -l richiede un formato lungo con ulteriori informazioni su ciascun asset (al momento solo il tipo). Puoi specificare --max_items number (o -m per breve) per limitare il numero di elementi di ogni cartella o raccolta elencata:

    earthengine ls -m 10 projects/my-project/assets/my_large_collection

L'esecuzione del comando ls senza argomenti elenca le cartelle di primo livello di tua proprietà.

modello

Strumento per manipolare i modelli salvati di TensorFlow.

model prepare

Prepara un modello salvato per la pubblicazione in Earth Engine. Nello specifico, trasforma il tuo SavedModel in un formato adatto per l'elaborazione delle richieste da Earth Engine. (Scopri di più su SavedModel.)

    earthengine model prepare my_source_dir my_dest_dir '{"Conv2D:0":"my_input_band"}' '{"Sigmoid:0":"my_output_band"}'

Scopri di più sui modelli di AI Platform qui. Vedi un example completo qui.

mv

Sposta o rinomina un asset. Esempio:

    earthengine mv projects/my-project/assets/asset_id projects/my-project/assets/new_asset_id

project_config

Imposta i valori di configurazione del progetto. Prima di utilizzare questo comando, assicurati di impostare un progetto utilizzando set_project.

get

Per visualizzare la configurazione di un progetto, utilizza il sottocomando get:

    earthengine alpha project_config get

Se disponi dell'autorizzazione per visualizzare le impostazioni delle attività batch del progetto, l'output contiene:

  • maxConcurrentExports: un numero che indica il numero massimo di attività in batch che possono essere eseguite in parallelo su tutti gli utenti per il progetto in questione. Per impostazione predefinita, questo valore è impostato sul valore massimo consentito dal piano di abbonamento dell'account di fatturazione associato.

Inoltre, se disponi dell'autorizzazione per visualizzare la configurazione del piano, l'output contiene:

  • planMaxConcurrentExports, un numero che indica il numero massimo di attività batch che possono essere eseguite in parallelo su tutti gli utenti e i progetti che utilizzano l'account di fatturazione.

imposta

Per aggiornare la configurazione del progetto, utilizza il sottocomando set. È possibile configurare le seguenti impostazioni:

Ad esempio, per configurare un progetto in modo da consentire l'esecuzione di massimo 10 attività in parallelo per il progetto in questione:

    earthengine alpha project_config set --max_concurrent_exports=10

L'output mostra la configurazione del progetto aggiornata, identica a quella restituita da get.

Per saperne di più sul parallelismo delle attività batch, consulta la pagina Quota di Earth Engine.

rm

Consente di eliminare uno o più asset. Esempio:

    earthengine rm projects/my-project/assets/asset_id
    earthengine rm -r projects/my-project/assets/folder_id

Puoi utilizzare il flag -r per eliminare i contenuti di una cartella o di una raccolta in modo ricorsivo. Per motivi di sicurezza, quando elimini più asset, puoi utilizzare il flag --dry_run per verificare esattamente cosa verrà eliminato senza eliminare nulla.

set_project

Imposta il progetto Google Cloud tramite il quale vengono inoltrate le richieste di calcolo.

    earthengine set_project foo-project

Questo comando è necessario prima di eseguire comandi che richiedono funzionalità Cloud, ad esempio model.

attività

Stampa informazioni su attività di lunga durata o le gestisce. Esempi:

    earthengine task list
    earthengine task list -l
    earthengine task info TASK_ID
    earthengine task cancel TASK_ID

Il sottocomando list elenca le informazioni di base sulle attività che hai inviato di recente. L'opzione -l richiede un formato lungo con maggiori informazioni su ogni attività. Il sottocomando info stampa informazioni dettagliate sulle singole attività. Il sottocomando cancel annulla una o più attività in esecuzione.

upload

Carica immagini o tabelle da Google Cloud Storage in Earth Engine oppure crea asset basati su immagini esterne.

immagine

Per caricare un asset immagine utilizzando le impostazioni predefinite:

    earthengine upload image --asset_id=projects/my-project/assets/asset_id gs://bucket/image.tif

Se specifichi più file immagine di input, questi verranno interpretati come riquadri di un singolo asset immagine. Puoi scoprire di più sulle opzioni per il caricamento delle immagini su Earth Engine in Caricare asset immagine: opzioni avanzate.

Puoi specificare il criterio di riduzione della piramide utilizzando il flag --pyramiding_policy, che può essere impostato su uno dei valori mean (valore predefinito), sample, mode, min o max. Questo controllerà il modo in cui Earth Engine genera la piramide di versioni con risoluzione inferiore dell'immagine:

    earthengine upload image --asset_id=projects/my-project/assets/asset_id --pyramiding_policy=sample gs://bucket/image.tif

Puoi utilizzare --last_band_alpha per indicare che la maschera per l'immagine deve essere ricavata da un canale alfa nell'ultima banda:

    earthengine upload image --asset_id=projects/my-project/assets/asset_id --last_band_alpha gs://bucket/image.tif

Puoi specificare un valore senza dati utilizzando il flag --nodata_value. Verranno mascherati tutti i pixel dell'immagine con quel valore:

    earthengine upload image --asset_id=users/myuser/asset --nodata_value=255 gs://bucket/image.tif

Puoi anche specificare le proprietà dei metadati da impostare sulla risorsa utilizzando gli stessi flag accettati dal comando asset set descritto sopra. Le opzioni sono descritte anche nella guida Manifesto delle immagini.

tabella

Per caricare un shapefile, un file CSV o un TFRecord da Google Cloud Storage in una risorsa tabella Earth Engine, puoi utilizzare uno dei seguenti metodi:

    earthengine upload table --asset_id=projects/my-project/assets/myUploadedShapefile gs://bucket/foo.shp
    earthengine upload table --asset_id=projects/my-project/assets/myUploadedCSV gs://bucket/foo.csv
    earthengine upload table --asset_id=projects/my-project/assets/myUploadedTFRecord gs://bucket/foo.tfrecord

Esistono molte opzioni relative al modo in cui vengono interpretati i file CSV e TFRecord. Puoi visualizzare un elenco completo delle opzioni di caricamento delle tabelle consultando la guida sul manifesto della tabella o con:

    earthengine upload table -h

external_image

Per creare una risorsa basata su un'immagine esterna, esegui il comando upload_image con un manifest:

earthengine alpha upload external_image --manifest /tmp/foo.json

Un manifest di esempio è:

{
  "name": "projects/{project}/assets/cogdemo1",
  "tilesets": [
    { "id": "0", "sources": [{ "uris": ["gs://ee-docs-demos/COG_demo.tif"] }] }
  ],
  "properties": {
    "source": "https://code.earthengine.google.com/d541cf8b268b2f9d8f834c255698201d"
  },
  "startTime": "2016-01-01T00:00:00.000000000Z",
  "endTime": "2016-12-31T15:01:23.000000000Z"
}

Per ulteriori dettagli sulla creazione del manifest, consulta la guida su Cloud GeoTIFF e la guida su Manifesto delle immagini.